// ============================================================================ // // Copyright (C) 2006-2016 Talend Inc. - www.talend.com // // This source code is available under agreement available at // %InstallDIR%\features\org.talend.rcp.branding.%PRODUCTNAME%\%PRODUCTNAME%license.txt // // You should have received a copy of the agreement // along with this program; if not, write to Talend SA // 9 rue Pages 92150 Suresnes, France // // ============================================================================ package org.talend.dataquality.datamasking.functions; import static org.junit.Assert.assertEquals; import java.util.Random; import org.junit.Before; import org.junit.Test; /** * @author dprot */ public class GenerateUniqueSsnChnTest { private String output; private AbstractGenerateUniqueSsn gnf = new GenerateUniqueSsnChn(); @Before public void setUp() throws Exception { gnf.setRandom(new Random(42)); gnf.setKeepFormat(true); } @Test public void testEmpty() { gnf.setKeepEmpty(true); output = gnf.generateMaskedRow(""); assertEquals("", output); //$NON-NLS-1$ } @Test public void testKeepInvalidPatternTrue() { gnf.setKeepInvalidPattern(true); output = gnf.generateMaskedRow(null); assertEquals(null, output); output = gnf.generateMaskedRow(""); assertEquals("", output); output = gnf.generateMaskedRow("AHDBNSKD"); assertEquals("AHDBNSKD", output); } @Test public void testKeepInvalidPatternFalse() { gnf.setKeepInvalidPattern(false); output = gnf.generateMaskedRow(null); assertEquals(null, output); output = gnf.generateMaskedRow(""); assertEquals(null, output); output = gnf.generateMaskedRow("AHDBNSKD"); assertEquals(null, output); } @Test public void testGood() { output = gnf.generateMaskedRow("64010119520414123X"); assertEquals("150923205211538130", output); } @Test public void testGoodSpace() { // with spaces output = gnf.generateMaskedRow("231202 19510411 456 4"); assertEquals("410422 19840319 136 X", output); } @Test public void testGoodLeapYear() { // leap year for date of birth output = gnf.generateMaskedRow("232723 19960229 459 4"); assertEquals("445322 19370707 229 X", output); } @Test public void testWrongSsnFieldNumber() { gnf.setKeepInvalidPattern(false); // without a number output = gnf.generateMaskedRow("6401011920414123X"); assertEquals(null, output); } @Test public void testWrongSsnFieldLetter() { gnf.setKeepInvalidPattern(false); // with a wrong letter output = gnf.generateMaskedRow("640101195204141C3X"); assertEquals(null, output); } @Test public void testWrongSsnFieldRegion() { gnf.setKeepInvalidPattern(false); // With an invalid region code output = gnf.generateMaskedRow("11000119520414123X"); assertEquals(null, output); } @Test public void testWrongSsnFieldBirth() { gnf.setKeepInvalidPattern(false); // With an invalid date of birth (wrong year) output = gnf.generateMaskedRow("64010118520414123X"); assertEquals(null, output); } @Test public void testWrongSsnFieldBirth2() { gnf.setKeepInvalidPattern(false); // With an invalid date of birth (day not existing) output = gnf.generateMaskedRow("64010119520434123X"); assertEquals(null, output); } @Test public void testWrongSsnFieldBirth3() { gnf.setKeepInvalidPattern(false); // With an invalid date of birth (29th February in a non-leap year) output = gnf.generateMaskedRow("64010119530229123X"); assertEquals(null, output); } }