From 676e53446285d1b8f514580fd9485d1f27493c0b Mon Sep 17 00:00:00 2001 From: Harald Welte Date: Mon, 14 Mar 2016 21:04:50 +0100 Subject: sim: Add simplistic unit test for APDU class tables --- tests/sim/sim_test.c | 57 +++++++++++++++++++++++++++++++++++++++++++++++++++ tests/sim/sim_test.ok | 6 ++++++ 2 files changed, 63 insertions(+) create mode 100644 tests/sim/sim_test.c create mode 100644 tests/sim/sim_test.ok (limited to 'tests/sim') diff --git a/tests/sim/sim_test.c b/tests/sim/sim_test.c new file mode 100644 index 00000000..4710c32e --- /dev/null +++ b/tests/sim/sim_test.c @@ -0,0 +1,57 @@ +/* + * (C) 2016 by Harald Welte + * All Rights Reserved + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + * + */ + +#include +#include +#include + +#include +#include + +const uint8_t sim_sel_mf[] = { 0xA0, 0xA4, 0x00, 0x00, 0x02, 0x3F, 0x00 }; +const uint8_t usim_sel_mf[] = { 0x00, 0xA4, 0x00, 0x00, 0x02, 0x3F, 0x00 }; +const uint8_t uicc_tprof[] = { 0x80, 0x10, 0x00, 0x00, 0x02, 0x01, 0x02 }; +const uint8_t uicc_tprof_wrong_class[] = { 0x00, 0x10, 0x00, 0x00, 0x02, 0x01, 0x02 }; +const uint8_t uicc_read[] = { 0x00, 0xB0, 0x00, 0x00, 0x10 }; +const uint8_t uicc_upd[] = { 0x00, 0xD6, 0x00, 0x00, 0x02, 0x01, 0x02 }; + +#define APDU_CASE_ASSERT(x, y) \ + do { \ + printf("Testing " #x "\n"); \ + int rc = osim_determine_apdu_case(&osim_uicc_sim_cic_profile, x); \ + if (rc != y) \ + printf("%d (actual) != %d (intended)\n", rc, y); \ + OSMO_ASSERT(rc == y); \ + } while (0) + +static void test_cla_ins_tbl(void) +{ + APDU_CASE_ASSERT(sim_sel_mf, 4); + APDU_CASE_ASSERT(usim_sel_mf, 4); + APDU_CASE_ASSERT(uicc_tprof, 3); + APDU_CASE_ASSERT(uicc_tprof_wrong_class, 0); + APDU_CASE_ASSERT(uicc_read, 2); + APDU_CASE_ASSERT(uicc_upd, 3); +} + +int main(int argc, char **argv) +{ + test_cla_ins_tbl(); +} diff --git a/tests/sim/sim_test.ok b/tests/sim/sim_test.ok new file mode 100644 index 00000000..7d3f986d --- /dev/null +++ b/tests/sim/sim_test.ok @@ -0,0 +1,6 @@ +Testing sim_sel_mf +Testing usim_sel_mf +Testing uicc_tprof +Testing uicc_tprof_wrong_class +Testing uicc_read +Testing uicc_upd -- cgit v1.2.3