From b5e8e4dc2bdeca39195a78d8d7f01bd7f099923c Mon Sep 17 00:00:00 2001 From: Jan Breuer <jan.breuer@jaybee.cz> Date: 周五, 13 11月 2015 18:54:29 +0800 Subject: [PATCH] Resolve #65: Cast char to unsigned in isctype functions --- libscpi/test/test_parser.c | 307 ++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 290 insertions(+), 17 deletions(-) diff --git a/libscpi/test/test_parser.c b/libscpi/test/test_parser.c index d2f5479..eefebaf 100644 --- a/libscpi/test/test_parser.c +++ b/libscpi/test/test_parser.c @@ -99,6 +99,7 @@ } scpi_t scpi_context; + static void error_buffer_clear(void) { err_buffer[0] = 0; err_buffer_pos = 0; @@ -112,7 +113,6 @@ err_buffer[err_buffer_pos] = err; err_buffer_pos++; } - static size_t SCPI_Write(scpi_t * context, const char * data, size_t len) { (void) context; @@ -135,6 +135,7 @@ } scpi_reg_val_t srq_val = 0; + static scpi_result_t SCPI_Control(scpi_t * context, scpi_ctrl_name_t ctrl, scpi_reg_val_t val) { (void) context; @@ -171,16 +172,17 @@ scpi_t scpi_context = { .cmdlist = scpi_commands, - .buffer = { + .buffer = + { .length = SCPI_INPUT_BUFFER_LENGTH, .data = scpi_input_buffer, }, .interface = &scpi_interface, .registers = scpi_regs, .units = scpi_units_def, - .idn = {"MA", "IN", NULL, "VER"}, + .idn = + {"MA", "IN", NULL, "VER"}, }; - static int init_suite(void) { SCPI_Init(&scpi_context); @@ -231,6 +233,10 @@ TEST_INPUT("TEST:TREEA?;:TEXT? \"PARAM1\", \"PARAM2\"\r\n", "10;\"PARAM2\"\r\n"); output_buffer_clear(); + /* Test special characters in parameters */ + TEST_INPUT("TEXT? \"\", \"test\r\n\"\r\n", "\"test\r\n\"\r\n"); + output_buffer_clear(); + CU_ASSERT_EQUAL(err_buffer_pos, 0); error_buffer_clear(); } @@ -239,19 +245,24 @@ output_buffer_clear(); error_buffer_clear(); -#define TEST_ERROR(data, output, err_num) { \ +#define TEST_ERROR(data, output, expected_result, err_num) { \ output_buffer_clear(); \ error_buffer_clear(); \ - SCPI_Input(&scpi_context, data, strlen(data)); \ + scpi_bool_t result = SCPI_Input(&scpi_context, data, strlen(data)); \ CU_ASSERT_STRING_EQUAL(output, output_buffer); \ - CU_ASSERT_EQUAL(err_buffer[0], err_num) \ + CU_ASSERT_EQUAL(err_buffer[0], err_num); \ + CU_ASSERT_EQUAL(result, expected_result); \ } - TEST_ERROR("*IDN?\r\n", "MA,IN,0,VER\r\n", 0); - TEST_ERROR("IDN?\r\n", "", SCPI_ERROR_UNDEFINED_HEADER); - TEST_ERROR("*ESE\r\n", "", SCPI_ERROR_MISSING_PARAMETER); - TEST_ERROR("*IDN? 12\r\n", "MA,IN,0,VER\r\n", SCPI_ERROR_PARAMETER_NOT_ALLOWED); - TEST_ERROR("TEXT? \"PARAM1\", \"PARAM2\"\r\n", "\"PARAM2\"\r\n", 0); + TEST_ERROR("*IDN?\r\n", "MA,IN,0,VER\r\n", TRUE, 0); + TEST_ERROR("IDN?\r\n", "", FALSE, SCPI_ERROR_UNDEFINED_HEADER); + TEST_ERROR("*ESE\r\n", "", FALSE, SCPI_ERROR_MISSING_PARAMETER); + TEST_ERROR("*IDN? 12\r\n", "MA,IN,0,VER\r\n", FALSE, SCPI_ERROR_PARAMETER_NOT_ALLOWED); + TEST_ERROR("TEXT? \"PARAM1\", \"PARAM2\"\r\n", "\"PARAM2\"\r\n", TRUE, 0); + TEST_ERROR("ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJ" + "ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJ" + "ABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJABCDEFGHIJ", + "", FALSE, SCPI_ERROR_INPUT_BUFFER_OVERRUN); // TODO: SCPI_ERROR_INVALID_SEPARATOR // TODO: SCPI_ERROR_INVALID_SUFFIX @@ -385,8 +396,8 @@ TEST_ParamUInt32("10V", TRUE, 0, FALSE, -138); // test range - TEST_ParamUInt32("2147483647", TRUE, 2147483647, TRUE, 0); - TEST_ParamUInt32("4294967295", TRUE, 4294967295, TRUE, 0); + TEST_ParamUInt32("2147483647", TRUE, 2147483647ULL, TRUE, 0); + TEST_ParamUInt32("4294967295", TRUE, 4294967295ULL, TRUE, 0); } #define TEST_ParamInt64(data, mandatory, expected_value, expected_result, expected_error_code) \ @@ -465,8 +476,8 @@ TEST_ParamUInt64("10V", TRUE, 0, FALSE, -138); // test range - TEST_ParamUInt64("2147483647", TRUE, 2147483647, TRUE, 0); - TEST_ParamUInt64("4294967295", TRUE, 4294967295, TRUE, 0); + TEST_ParamUInt64("2147483647", TRUE, 2147483647ULL, TRUE, 0); + TEST_ParamUInt64("4294967295", TRUE, 4294967295ULL, TRUE, 0); TEST_ParamUInt64("9223372036854775807", TRUE, 9223372036854775807ULL, TRUE, 0); TEST_ParamUInt64("18446744073709551615", TRUE, 18446744073709551615ULL, TRUE, 0); } @@ -748,7 +759,7 @@ TEST_ChannelList("(@1,2:3)", 2, 1, FALSE, 0, (0), (0), SCPI_EXPR_NO_MORE, 0); TEST_ChannelList("(@1,2!5:3!6)", 0, 2, FALSE, 1, (1), (0), SCPI_EXPR_OK, 0); - TEST_ChannelList("(@1,2!5:3!6)", 1, 2, TRUE, 2, (2,5), (3,6), SCPI_EXPR_OK, 0); + TEST_ChannelList("(@1,2!5:3!6)", 1, 2, TRUE, 2, (2, 5), (3, 6), SCPI_EXPR_OK, 0); TEST_ChannelList("(@1,2!5:3!6)", 2, 2, FALSE, 0, (0), (0), SCPI_EXPR_NO_MORE, 0); TEST_ChannelList("(@1,2!5:3!6)", 0, 1, FALSE, 1, (1), (0), SCPI_EXPR_OK, 0); @@ -758,6 +769,253 @@ TEST_ChannelList("(@1,2!5:3!6!7)", 0, 2, FALSE, 1, (1), (0), SCPI_EXPR_OK, 0); TEST_ChannelList("(@1,2!5:3!6!7)", 1, 2, FALSE, 0, (0), (0), SCPI_EXPR_ERROR, SCPI_ERROR_EXPRESSION_PARSING_ERROR); TEST_ChannelList("(@1,2!5:3!6!7)", 2, 2, FALSE, 0, (0), (0), SCPI_EXPR_ERROR, SCPI_ERROR_EXPRESSION_PARSING_ERROR); + + TEST_ChannelList("(@1, 2)", 0, 1, FALSE, 1, (1), (0), SCPI_EXPR_OK, 0); + TEST_ChannelList("(@1, 2)", 1, 1, FALSE, 0, (0), (0), SCPI_EXPR_ERROR, SCPI_ERROR_EXPRESSION_PARSING_ERROR); +} + + +#define TEST_ParamNumber(data, mandatory, expected_special, expected_tag, expected_value, expected_unit, expected_base, expected_result, expected_error_code) \ +{ \ + scpi_number_t value; \ + scpi_bool_t result; \ + int16_t errCode; \ + \ + SCPI_CoreCls(&scpi_context); \ + scpi_context.input_count = 0; \ + scpi_context.param_list.lex_state.buffer = data; \ + scpi_context.param_list.lex_state.len = strlen(scpi_context.param_list.lex_state.buffer);\ + scpi_context.param_list.lex_state.pos = scpi_context.param_list.lex_state.buffer; \ + result = SCPI_ParamNumber(&scpi_context, scpi_special_numbers_def, &value, mandatory);\ + \ + errCode = SCPI_ErrorPop(&scpi_context); \ + CU_ASSERT_EQUAL(result, expected_result); \ + if (expected_result) { \ + CU_ASSERT_EQUAL(value.special, expected_special); \ + if (value.special) CU_ASSERT_EQUAL(value.tag, expected_tag); \ + if (!value.special) CU_ASSERT_DOUBLE_EQUAL(value.value, expected_value, 0.000001);\ + CU_ASSERT_EQUAL(value.unit, expected_unit); \ + CU_ASSERT_EQUAL(value.base, expected_base); \ + } \ + CU_ASSERT_EQUAL(errCode, expected_error_code); \ +} + +static void testParamNumber(void) { + TEST_ParamNumber("1", TRUE, FALSE, SCPI_NUM_NUMBER, 1, SCPI_UNIT_NONE, 10, TRUE, 0); + TEST_ParamNumber("#Q20", TRUE, FALSE, SCPI_NUM_NUMBER, 16, SCPI_UNIT_NONE, 8, TRUE, 0); + TEST_ParamNumber("#H20", TRUE, FALSE, SCPI_NUM_NUMBER, 32, SCPI_UNIT_NONE, 16, TRUE, 0); + TEST_ParamNumber("#B11", TRUE, FALSE, SCPI_NUM_NUMBER, 3, SCPI_UNIT_NONE, 2, TRUE, 0); + TEST_ParamNumber("1.2", TRUE, FALSE, SCPI_NUM_NUMBER, 1.2, SCPI_UNIT_NONE, 10, TRUE, 0); + TEST_ParamNumber("1.2e-1", TRUE, FALSE, SCPI_NUM_NUMBER, 0.12, SCPI_UNIT_NONE, 10, TRUE, 0); + TEST_ParamNumber("1.2e-1V", TRUE, FALSE, SCPI_NUM_NUMBER, 0.12, SCPI_UNIT_VOLT, 10, TRUE, 0); + TEST_ParamNumber("1.2mV", TRUE, FALSE, SCPI_NUM_NUMBER, 0.0012, SCPI_UNIT_VOLT, 10, TRUE, 0); + TEST_ParamNumber("100 OHM", TRUE, FALSE, SCPI_NUM_NUMBER, 100, SCPI_UNIT_OHM, 10, TRUE, 0); + TEST_ParamNumber("min", TRUE, TRUE, SCPI_NUM_MIN, 0, SCPI_UNIT_NONE, 10, TRUE, 0); + TEST_ParamNumber("infinity", TRUE, TRUE, SCPI_NUM_INF, 0, SCPI_UNIT_NONE, 10, TRUE, 0); + TEST_ParamNumber("minc", TRUE, TRUE, SCPI_NUM_NUMBER, 0, SCPI_UNIT_NONE, 10, FALSE, SCPI_ERROR_ILLEGAL_PARAMETER_VALUE); +} + +#define TEST_Result(func, value, expected_result) \ +{\ + output_buffer_clear();\ + scpi_context.output_count = 0;\ + size_t expected_len = strlen(expected_result);\ + size_t len = SCPI_Result##func(&scpi_context, (value));\ + CU_ASSERT_EQUAL(len, expected_len);\ + CU_ASSERT_EQUAL(output_buffer_pos, expected_len);\ + CU_ASSERT_EQUAL(memcmp(output_buffer, expected_result, expected_len), 0);\ +} + +#define TEST_ResultBase(func, value, base, expected_result) \ +{\ + output_buffer_clear();\ + scpi_context.output_count = 0;\ + size_t expected_len = strlen(expected_result);\ + size_t len = SCPI_Result##func##Base(&scpi_context, (value), (base));\ + CU_ASSERT_EQUAL(len, expected_len);\ + CU_ASSERT_EQUAL(output_buffer_pos, expected_len);\ + CU_ASSERT_EQUAL(memcmp(output_buffer, expected_result, expected_len), 0);\ +} + +static void testResultInt8(void) { + TEST_Result(Int8, 10, "10"); + TEST_Result(Int8, -10, "-10"); + TEST_Result(Int8, 100, "100"); + TEST_Result(Int8, -100, "-100"); + TEST_Result(Int8, 256, "0"); + TEST_Result(Int8, 1111, "87"); + TEST_Result(Int8, 127, "127"); + TEST_Result(Int8, -128, "-128"); +} + +static void testResultUInt8(void) { + TEST_Result(UInt8, 10, "10"); + TEST_Result(UInt8, -10, "246"); + TEST_Result(UInt8, 100, "100"); + TEST_Result(UInt8, -100, "156"); + TEST_Result(UInt8, 256, "0"); + TEST_Result(UInt8, 1111, "87"); + TEST_Result(UInt8, 127, "127"); + TEST_Result(UInt8, -128, "128"); + TEST_Result(UInt8, 0, "0"); + TEST_Result(UInt8, 255, "255"); + + TEST_ResultBase(UInt8, 0xff, 16, "#HFF"); + TEST_ResultBase(UInt8, 0xff, 8, "#Q377"); + TEST_ResultBase(UInt8, 0xff, 2, "#B11111111"); +} + +static void testResultInt16(void) { + TEST_Result(Int16, 10, "10"); + TEST_Result(Int16, -10, "-10"); + TEST_Result(Int16, 100, "100"); + TEST_Result(Int16, -100, "-100"); + TEST_Result(Int16, 256, "256"); + TEST_Result(Int16, 1111, "1111"); + TEST_Result(Int16, 127, "127"); + TEST_Result(Int16, -128, "-128"); + TEST_Result(Int16, 111111, "-19961"); + TEST_Result(Int16, 32767, "32767"); + TEST_Result(Int16, -32768, "-32768"); +} + +static void testResultUInt16(void) { + TEST_Result(UInt16, 10, "10"); + TEST_Result(UInt16, -10, "65526"); + TEST_Result(UInt16, 100, "100"); + TEST_Result(UInt16, -100, "65436"); + TEST_Result(UInt16, 256, "256"); + TEST_Result(UInt16, 1111, "1111"); + TEST_Result(UInt16, 127, "127"); + TEST_Result(UInt16, -128, "65408"); + TEST_Result(UInt16, 111111, "45575"); + TEST_Result(UInt16, 32767, "32767"); + TEST_Result(UInt16, -32768, "32768"); + TEST_Result(UInt16, 65535, "65535"); + + TEST_ResultBase(UInt16, 0xffff, 16, "#HFFFF"); + TEST_ResultBase(UInt16, 0xffff, 8, "#Q177777"); + TEST_ResultBase(UInt16, 0xffff, 2, "#B1111111111111111"); +} + +static void testResultInt32(void) { + TEST_Result(Int32, 10, "10"); + TEST_Result(Int32, -10, "-10"); + TEST_Result(Int32, 2147483647L, "2147483647"); + //TEST_Result(Int32, -2147483648L, "-2147483648"); // bug in GCC + TEST_Result(Int32, -2147483647L, "-2147483647"); +} + +static void testResultUInt32(void) { + TEST_Result(UInt32, 10, "10"); + TEST_Result(UInt32, -10, "4294967286"); + TEST_Result(UInt32, 2147483647L, "2147483647"); + //TEST_Result(UInt32, -2147483648L, "2147483648"); // bug in GCC + TEST_Result(UInt32, -2147483647L, "2147483649"); + TEST_Result(UInt32, 4294967295UL, "4294967295"); + + TEST_ResultBase(UInt32, 0xffffffff, 16, "#HFFFFFFFF"); + TEST_ResultBase(UInt32, 0xffffffff, 8, "#Q37777777777"); + TEST_ResultBase(UInt32, 0xffffffff, 2, "#B11111111111111111111111111111111"); +} + +static void testResultInt64(void) { + TEST_Result(Int64, 10, "10"); + TEST_Result(Int64, -10, "-10"); + TEST_Result(Int64, 127, "127"); + TEST_Result(Int64, -128, "-128"); + TEST_Result(Int64, 32767, "32767"); + TEST_Result(Int64, -32768, "-32768"); + TEST_Result(Int64, 2147483647L, "2147483647"); + //TEST_Result(Int64, -2147483648, "-2147483648"); // bug in gcc + TEST_Result(Int64, -2147483647L, "-2147483647"); + TEST_Result(Int64, 9223372036854775807LL, "9223372036854775807"); + //TEST_Result(Int64, -9223372036854775808LL, "-9223372036854775808"); bug in GCC + TEST_Result(Int64, -9223372036854775807LL, "-9223372036854775807"); +} + +static void testResultUInt64(void) { + TEST_Result(UInt64, 10, "10"); + TEST_Result(UInt64, -10, "18446744073709551606"); + TEST_Result(UInt64, 127, "127"); + TEST_Result(UInt64, -128, "18446744073709551488"); + TEST_Result(UInt64, 32767, "32767"); + TEST_Result(UInt64, -32768, "18446744073709518848"); + TEST_Result(UInt64, 2147483647L, "2147483647"); + //TEST_Result(UInt64, -2147483648L, "18446744071562067968"); // bug in GCC + TEST_Result(UInt64, -2147483647L, "18446744071562067969"); + TEST_Result(UInt64, 9223372036854775807LL, "9223372036854775807"); + //TEST_Result(Int64, -9223372036854775808LL, "9223372036854775808"); bug in GCC + TEST_Result(UInt64, -9223372036854775807LL, "9223372036854775809"); + TEST_Result(UInt64, 18446744073709551615ULL, "18446744073709551615"); + + TEST_ResultBase(UInt64, 0xffffffffffffffffULL, 16, "#HFFFFFFFFFFFFFFFF"); + TEST_ResultBase(UInt64, 0xffffffffffffffffULL, 8, "#Q1777777777777777777777"); + TEST_ResultBase(UInt64, 0xffffffffffffffffULL, 2, "#B1111111111111111111111111111111111111111111111111111111111111111"); +} + +static void testResultFloat(void) { + TEST_Result(Float, 10, "10"); + TEST_Result(Float, -10, "-10"); + TEST_Result(Float, 127, "127"); + TEST_Result(Float, -128, "-128"); + TEST_Result(Float, 32767, "32767"); + TEST_Result(Float, -32768, "-32768"); + TEST_Result(Float, 2147483647L, "2.14748e+09"); + //TEST_Result(Float, -2147483648, "-2.14748e+09"); // bug in GCC + TEST_Result(Float, -2147483647L, "-2.14748e+09"); + TEST_Result(Float, 9223372036854775807LL, "9.22337e+18"); + TEST_Result(Float, -9223372036854775807LL, "-9.22337e+18"); + + TEST_Result(Float, 1.256e-17, "1.256e-17"); + TEST_Result(Float, -1.256e-17, "-1.256e-17"); +} + +static void testResultDouble(void) { + TEST_Result(Double, 10, "10"); + TEST_Result(Double, -10, "-10"); + TEST_Result(Double, 127, "127"); + TEST_Result(Double, -128, "-128"); + TEST_Result(Double, 32767, "32767"); + TEST_Result(Double, -32768, "-32768"); + TEST_Result(Double, 2147483647, "2147483647"); + //TEST_Result(Double, -2147483648, "-2147483648"); // bug in GCC + TEST_Result(Double, -2147483647, "-2147483647"); + TEST_Result(Double, 9223372036854775807LL, "9.22337203685478e+18"); + TEST_Result(Double, -9223372036854775807LL, "-9.22337203685478e+18"); + + TEST_Result(Double, 1.256e-17, "1.256e-17"); + TEST_Result(Double, -1.256e-17, "-1.256e-17"); +} + +static void testResultBool(void) { + TEST_Result(Bool, TRUE, "1"); + TEST_Result(Bool, FALSE, "0"); + TEST_Result(Bool, 1000, "1"); +} + +static void testResultMnemonic(void) { + TEST_Result(Mnemonic, "a", "a"); + TEST_Result(Mnemonic, "abcd", "abcd"); + TEST_Result(Mnemonic, "abcd123", "abcd123"); +} + +static void testResultText(void) { + TEST_Result(Text, "a", "\"a\""); + TEST_Result(Text, "abcd", "\"abcd\""); + TEST_Result(Text, "abcd123", "\"abcd123\""); + TEST_Result(Text, "abcd\"123", "\"abcd\"\"123\""); + TEST_Result(Text, "abcd\"", "\"abcd\"\"\""); +} + +static void testResultArbitraryBlock(void) { +#define SCPI_ResultArbitraryBlockString(c, s) SCPI_ResultArbitraryBlock((c), (s), strlen(s)) + + TEST_Result(ArbitraryBlockString, "a", "#11a"); + TEST_Result(ArbitraryBlockString, "a\"", "#12a\""); + TEST_Result(ArbitraryBlockString, "a\r\n", "#13a\r\n"); + TEST_Result(ArbitraryBlockString, "X1234567890", "#211X1234567890"); + TEST_Result(ArbitraryBlockString, "X1234567890\x80x", "#213X1234567890\x80x"); } int main() { @@ -789,6 +1047,21 @@ || (NULL == CU_add_test(pSuite, "IEEE 488.2 Mandatory commands", testIEEE4882)) || (NULL == CU_add_test(pSuite, "Numeric list", testNumericList)) || (NULL == CU_add_test(pSuite, "Channel list", testChannelList)) + || (NULL == CU_add_test(pSuite, "SCPI_ParamNumber", testParamNumber)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultInt8", testResultInt8)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultUInt8", testResultUInt8)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultInt16", testResultInt16)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultUInt16", testResultUInt16)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultInt32", testResultInt32)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultUInt32", testResultUInt32)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultInt64", testResultInt64)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultUInt64", testResultUInt64)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultFloat", testResultFloat)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultDouble", testResultDouble)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultBool", testResultBool)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultMnemonic", testResultMnemonic)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultText", testResultText)) + || (NULL == CU_add_test(pSuite, "SCPI_ResultArbitraryBlock", testResultArbitraryBlock)) ) { CU_cleanup_registry(); return CU_get_error(); -- Gitblit v1.9.1