From dc61d491979ba8f1e6d70d129cf2659bbda1079c Mon Sep 17 00:00:00 2001 From: devnied Date: Tue, 2 Sep 2014 12:55:48 +0200 Subject: [PATCH] Add unit tests --- .../devnied/emvnfccard/EmvParserTest.java | 33 +++++++++++ .../provider/PpseProviderMasterCard2Test.java | 58 +++++++++++++++++++ 2 files changed, 91 insertions(+) create mode 100644 library/src/test/java/com/github/devnied/emvnfccard/provider/PpseProviderMasterCard2Test.java diff --git a/library/src/test/java/com/github/devnied/emvnfccard/EmvParserTest.java b/library/src/test/java/com/github/devnied/emvnfccard/EmvParserTest.java index 730a33aa..fc1ef1c7 100644 --- a/library/src/test/java/com/github/devnied/emvnfccard/EmvParserTest.java +++ b/library/src/test/java/com/github/devnied/emvnfccard/EmvParserTest.java @@ -25,6 +25,7 @@ import com.github.devnied.emvnfccard.parser.EmvParser; import com.github.devnied.emvnfccard.parser.IProvider; import com.github.devnied.emvnfccard.provider.ExceptionProviderTest; +import com.github.devnied.emvnfccard.provider.PpseProviderMasterCard2Test; import com.github.devnied.emvnfccard.provider.PpseProviderMasterCardTest; import com.github.devnied.emvnfccard.provider.PpseProviderVisa2Test; import com.github.devnied.emvnfccard.provider.PpseProviderVisaNulTransactionsTest; @@ -108,6 +109,38 @@ public void testPPSEMasterCard() throws CommunicationException { Assertions.assertThat(sdf.format(card.getExpireDate())).isEqualTo("09/2015"); } + @Test + public void testPPSEMasterCard2() throws CommunicationException { + + IProvider prov = new PpseProviderMasterCard2Test(); + + EmvParser parser = new EmvParser(prov, true); + EmvCard card = parser.readEmvCard(); + + if (card != null) { + LOGGER.debug(card.toString()); + } + Assertions.assertThat(card).isNotNull(); + Assertions.assertThat(card.getAid()).isEqualTo("A0000000041010"); + Assertions.assertThat(card.getCardNumber()).isEqualTo("5200000000000000"); + Assertions.assertThat(card.getType()).isEqualTo(EmvCardScheme.MASTER_CARD); + Assertions.assertThat(card.getHolderName()).isEqualTo(null); + Assertions.assertThat(card.getLeftPinTry()).isEqualTo(2); + Assertions.assertThat(card.getApplicationLabel()).isEqualTo(null); + SimpleDateFormat sdf = new SimpleDateFormat("MM/yyyy"); + Assertions.assertThat(sdf.format(card.getExpireDate())).isEqualTo("10/2002"); + Assertions.assertThat(card.getListTransactions()).isNotEmpty(); + Assertions.assertThat(card.getListTransactions().size()).isEqualTo(10); + EmvTransactionRecord record = card.getListTransactions().get(0); + Assertions.assertThat(record.getAmount()).isEqualTo(2200); + Assertions.assertThat(record.getCyptogramData()).isEqualTo("40"); + Assertions.assertThat(record.getCurrency()).isEqualTo(CurrencyEnum.TRY); + Assertions.assertThat(record.getTransactionDate()).isNotNull(); + SimpleDateFormat sdf2 = new SimpleDateFormat("dd/MM/yyyy"); + Assertions.assertThat(sdf2.format(record.getTransactionDate())).isEqualTo("12/01/2011"); + + } + @Test public void testPPSEVisa2() throws CommunicationException { diff --git a/library/src/test/java/com/github/devnied/emvnfccard/provider/PpseProviderMasterCard2Test.java b/library/src/test/java/com/github/devnied/emvnfccard/provider/PpseProviderMasterCard2Test.java new file mode 100644 index 00000000..d7bae2ed --- /dev/null +++ b/library/src/test/java/com/github/devnied/emvnfccard/provider/PpseProviderMasterCard2Test.java @@ -0,0 +1,58 @@ +package com.github.devnied.emvnfccard.provider; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import com.github.devnied.emvnfccard.parser.IProvider; +import com.github.devnied.emvnfccard.utils.TlvUtil; + +import fr.devnied.bitlib.BytesUtils; + +public class PpseProviderMasterCard2Test implements IProvider { + + private static final Logger LOGGER = LoggerFactory.getLogger(PpseProviderMasterCard2Test.class); + + private int step; + + @Override + public byte[] transceive(final byte[] pCommand) { + String response = null; + LOGGER.debug("send: " + BytesUtils.bytesToString(pCommand)); + switch (step++) { + + case 0: + response = "6F 23 84 0E 32 50 41 59 2E 53 59 53 2E 44 44 46 30 31 A5 11 BF 0C 0E 61 0C 4F 07 A0 00 00 00 04 10 10 87 01 01 90 00"; + break; + case 1: + response = "6F 7D 84 07 A0 00 00 00 04 10 10 A5 72 50 10 44 45 42 49 54 20 4D 41 53 54 45 52 43 41 52 44 9F 12 0A 4D 41 53 54 45 52 43 41 52 44 87 01 01 9F 11 01 09 9F 38 03 9F 5C 08 BF 0C 43 42 03 52 82 08 9F 5D 03 01 03 00 9F 5E 09 52 00 00 00 00 00 00 00 01 9F 4D 02 0B 0A DF 64 20 02 50 48 43 45 4E 42 4B 52 54 20 41 4E 43 30 30 31 4F 4E 20 01 01 4E 4E 50 00 00 00 00 00 00 00 DF 65 01 01 90 00"; + break; + case 2: + response = "77 12 82 02 19 80 94 0C 08 01 01 00 10 01 01 01 20 02 03 00 90 00"; + break; + case 3: + response = "70 6B 9F 6C 02 00 01 9F 62 06 00 00 00 00 0E 00 9F 63 06 00 00 00 00 00 7E 56 2A 42 35 30 30 32 30 30 30 30 30 35 34 35 37 37 32 36 5E 20 2F 5E 32 31 31 32 32 30 32 30 30 30 30 30 31 30 30 30 30 30 30 30 30 9F 64 01 03 9F 65 02 00 0E 9F 66 02 0E 70 9F 6B 13 52 00 00 00 00 00 00 00 D0 11 92 02 00 00 01 00 00 00 0F 9F 67 01 03 90 00"; + break; + case 4: + response = "70 81 B6 5F 25 03 13 12 01 5F 24 03 21 12 31 5A 08 52 00 00 00 00 00 00 00 5F 34 01 01 9F 07 02 3D 00 9F 08 02 00 02 8C 27 9F 02 06 9F 03 06 9F 1A 02 95 05 5F 2A 02 9A 03 9C 01 9F 37 04 9F 35 01 9F 45 02 9F 4C 08 9F 34 03 9F 21 03 9F 7C 14 8D 0C 91 0A 8A 02 95 05 9F 37 04 9F 4C 08 8E 0E 00 00 00 00 00 00 00 00 42 03 1E 03 1F 03 9F 51 03 9F 37 04 9F 5B 0C DF 60 08 DF 61 08 DF 62 01 DF 63 A0 9F 0D 05 B4 50 84 00 00 9F 0E 05 00 10 80 00 00 9F 0F 05 B4 70 84 80 00 5F 28 02 07 92 9F 4A 01 82 57 13 52 00 00 00 00 00 00 00 D0 12 22 26 70 10 10 00 00 00 0F 90 00"; + break; + case 5: + response = "9F 4F 1A 9F 27 01 9F 02 06 5F 2A 02 9A 03 9F 36 02 9F 52 06 DF 3E 01 9F 21 03 9F 7C 14 90 00"; + break; + + default: + response = "40 00 00 00 00 22 00 09 49 11 01 12 00 E0 61 90 22 21 00 00 00 00 50 23 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 90 00"; + } + + if (BytesUtils.bytesToStringNoSpace(pCommand).equals("80CA9F1700")) { + response = "9F 17 01 02 90 00"; + } + + LOGGER.debug("resp: " + response); + byte[] ret = BytesUtils.fromString(response); + try { + LOGGER.debug(TlvUtil.prettyPrintAPDUResponse(ret)); + } catch (Exception e) { + } + return ret; + } +}