diff options
| author | 2021-12-23 03:09:07 +0100 | |
|---|---|---|
| committer | 2021-12-23 03:09:07 +0100 | |
| commit | 429cbc660ae14d4998715803b44c71abf0e4a339 (patch) | |
| tree | 12fe08f5dcb00a380536198bac3fffd4eb7dd19b /test | |
| parent | 70002721443dabaa99b56301b537980e137b6249 (diff) | |
| download | libplist-429cbc660ae14d4998715803b44c71abf0e4a339.tar.gz libplist-429cbc660ae14d4998715803b44c71abf0e4a339.tar.bz2 | |
Add support for JSON format
Diffstat (limited to 'test')
| -rw-r--r-- | test/Makefile.am | 15 | ||||
| -rwxr-xr-x | test/amp.test | 8 | ||||
| -rw-r--r-- | test/data/data.bplist | bin | 0 -> 3718 bytes | |||
| -rw-r--r-- | test/data/j1.plist | 1 | ||||
| -rwxr-xr-x | test/invalid_tag.test | 8 | ||||
| -rwxr-xr-x | test/json-invalid-types.test | 36 | ||||
| -rwxr-xr-x | test/json1.test | 19 | ||||
| -rwxr-xr-x | test/json2.test | 22 | ||||
| -rwxr-xr-x | test/malformed_dict.test | 8 | ||||
| -rw-r--r-- | test/plist_cmp.c | 4 | ||||
| -rw-r--r-- | test/plist_jtest.c | 131 | ||||
| -rwxr-xr-x | test/recursion.test | 8 |
12 files changed, 247 insertions, 13 deletions
diff --git a/test/Makefile.am b/test/Makefile.am index 3fca55f..b70a85d 100644 --- a/test/Makefile.am +++ b/test/Makefile.am | |||
| @@ -8,7 +8,8 @@ AM_LDFLAGS = | |||
| 8 | noinst_PROGRAMS = \ | 8 | noinst_PROGRAMS = \ |
| 9 | plist_cmp \ | 9 | plist_cmp \ |
| 10 | plist_test \ | 10 | plist_test \ |
| 11 | plist_btest | 11 | plist_btest \ |
| 12 | plist_jtest | ||
| 12 | 13 | ||
| 13 | plist_cmp_SOURCES = plist_cmp.c | 14 | plist_cmp_SOURCES = plist_cmp.c |
| 14 | plist_cmp_LDADD = \ | 15 | plist_cmp_LDADD = \ |
| @@ -21,6 +22,9 @@ plist_test_LDADD = $(top_builddir)/src/libplist-2.0.la | |||
| 21 | plist_btest_SOURCES = plist_btest.c | 22 | plist_btest_SOURCES = plist_btest.c |
| 22 | plist_btest_LDADD = $(top_builddir)/src/libplist-2.0.la | 23 | plist_btest_LDADD = $(top_builddir)/src/libplist-2.0.la |
| 23 | 24 | ||
| 25 | plist_jtest_SOURCES = plist_jtest.c | ||
| 26 | plist_jtest_LDADD = $(top_builddir)/src/libplist-2.0.la | ||
| 27 | |||
| 24 | TESTS = \ | 28 | TESTS = \ |
| 25 | empty.test \ | 29 | empty.test \ |
| 26 | small.test \ | 30 | small.test \ |
| @@ -45,7 +49,10 @@ TESTS = \ | |||
| 45 | offsetsize.test \ | 49 | offsetsize.test \ |
| 46 | refsize.test \ | 50 | refsize.test \ |
| 47 | malformed_dict.test \ | 51 | malformed_dict.test \ |
| 48 | uid.test | 52 | uid.test \ |
| 53 | json1.test \ | ||
| 54 | json2.test \ | ||
| 55 | json-invalid-types.test | ||
| 49 | 56 | ||
| 50 | EXTRA_DIST = \ | 57 | EXTRA_DIST = \ |
| 51 | $(TESTS) \ | 58 | $(TESTS) \ |
| @@ -89,7 +96,9 @@ EXTRA_DIST = \ | |||
| 89 | data/signedunsigned.plist \ | 96 | data/signedunsigned.plist \ |
| 90 | data/unsigned.bplist \ | 97 | data/unsigned.bplist \ |
| 91 | data/unsigned.plist \ | 98 | data/unsigned.plist \ |
| 92 | data/uid.bplist | 99 | data/uid.bplist \ |
| 100 | data/data.bplist \ | ||
| 101 | data/j1.plist | ||
| 93 | 102 | ||
| 94 | TESTS_ENVIRONMENT = \ | 103 | TESTS_ENVIRONMENT = \ |
| 95 | top_srcdir=$(top_srcdir) \ | 104 | top_srcdir=$(top_srcdir) \ |
diff --git a/test/amp.test b/test/amp.test index 0815391..76b32ff 100755 --- a/test/amp.test +++ b/test/amp.test | |||
| @@ -1,7 +1,5 @@ | |||
| 1 | ## -*- sh -*- | 1 | ## -*- sh -*- |
| 2 | 2 | ||
| 3 | set -e | ||
| 4 | |||
| 5 | DATASRC=$top_srcdir/test/data | 3 | DATASRC=$top_srcdir/test/data |
| 6 | TESTFILE=amp.plist | 4 | TESTFILE=amp.plist |
| 7 | DATAIN0=$DATASRC/$TESTFILE | 5 | DATAIN0=$DATASRC/$TESTFILE |
| @@ -9,6 +7,10 @@ DATAOUT0=$top_builddir/test/data/$TESTFILE.out | |||
| 9 | 7 | ||
| 10 | rm -rf $DATAOUT0 | 8 | rm -rf $DATAOUT0 |
| 11 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 | 9 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 |
| 12 | if test -f $DATAOUT0; then | 10 | |
| 11 | # test succeeds if plistutil fails | ||
| 12 | if [ $? -eq 0 ]; then | ||
| 13 | exit 1 | 13 | exit 1 |
| 14 | else | ||
| 15 | exit 0 | ||
| 14 | fi | 16 | fi |
diff --git a/test/data/data.bplist b/test/data/data.bplist new file mode 100644 index 0000000..955993f --- /dev/null +++ b/test/data/data.bplist | |||
| Binary files differ | |||
diff --git a/test/data/j1.plist b/test/data/j1.plist new file mode 100644 index 0000000..2ae9acb --- /dev/null +++ b/test/data/j1.plist | |||
| @@ -0,0 +1 @@ | |||
| {"test":[1,1],"foo":[[1],[1],[1],[1],[[1],[1],[1],[1],[[1],[1],[1],[1]]]],"more":{"a":"yo","b":[{"c":0.25},{"a":"yo","b":[{"c":0.25},{"a":"yo","b":[{"c":0.25}]}]}]}} \ No newline at end of file | |||
diff --git a/test/invalid_tag.test b/test/invalid_tag.test index 079bcdd..2c42a53 100755 --- a/test/invalid_tag.test +++ b/test/invalid_tag.test | |||
| @@ -1,7 +1,5 @@ | |||
| 1 | ## -*- sh -*- | 1 | ## -*- sh -*- |
| 2 | 2 | ||
| 3 | set -e | ||
| 4 | |||
| 5 | DATASRC=$top_srcdir/test/data | 3 | DATASRC=$top_srcdir/test/data |
| 6 | TESTFILE=invalid_tag.plist | 4 | TESTFILE=invalid_tag.plist |
| 7 | DATAIN0=$DATASRC/$TESTFILE | 5 | DATAIN0=$DATASRC/$TESTFILE |
| @@ -9,6 +7,10 @@ DATAOUT0=$top_builddir/test/data/$TESTFILE.out | |||
| 9 | 7 | ||
| 10 | rm -rf $DATAOUT0 | 8 | rm -rf $DATAOUT0 |
| 11 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 | 9 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 |
| 12 | if test -f $DATAOUT0; then | 10 | |
| 11 | # test succeeds if plistutil fails | ||
| 12 | if [ $? -eq 0 ]; then | ||
| 13 | exit 1 | 13 | exit 1 |
| 14 | else | ||
| 15 | exit 0 | ||
| 14 | fi | 16 | fi |
diff --git a/test/json-invalid-types.test b/test/json-invalid-types.test new file mode 100755 index 0000000..0397c05 --- /dev/null +++ b/test/json-invalid-types.test | |||
| @@ -0,0 +1,36 @@ | |||
| 1 | ## -*- sh -*- | ||
| 2 | |||
| 3 | DATASRC=$top_srcdir/test/data | ||
| 4 | DATAOUT=$top_builddir/test/data | ||
| 5 | TESTFILE0=data.bplist | ||
| 6 | TESTFILE1=7.plist | ||
| 7 | TESTFILE2=uid.bplist | ||
| 8 | |||
| 9 | if ! test -d "$DATAOUT"; then | ||
| 10 | mkdir -p $DATAOUT | ||
| 11 | fi | ||
| 12 | |||
| 13 | export PLIST_JSON_DEBUG=1 | ||
| 14 | |||
| 15 | echo "Converting (failure expected)" | ||
| 16 | STDERR=`$top_builddir/tools/plistutil -f json -i $DATASRC/$TESTFILE0 -o /dev/null 2>&1` | ||
| 17 | echo "$STDERR" | ||
| 18 | if ! echo "$STDERR" |grep "PLIST_DATA type is not valid for JSON format"; then | ||
| 19 | exit 1 | ||
| 20 | fi | ||
| 21 | |||
| 22 | echo "Converting (failure expected)" | ||
| 23 | STDERR=`$top_builddir/tools/plistutil -f json -i $DATASRC/$TESTFILE1 -o /dev/null 2>&1` | ||
| 24 | echo "$STDERR" | ||
| 25 | if ! echo "$STDERR" |grep "PLIST_DATE type is not valid for JSON format"; then | ||
| 26 | exit 2 | ||
| 27 | fi | ||
| 28 | |||
| 29 | echo "Converting (failure expected)" | ||
| 30 | STDERR=`$top_builddir/tools/plistutil -f json -i $DATASRC/$TESTFILE2 -o /dev/null 2>&1` | ||
| 31 | echo "$STDERR" | ||
| 32 | if ! echo "$STDERR" |grep "PLIST_UID type is not valid for JSON format"; then | ||
| 33 | exit 3 | ||
| 34 | fi | ||
| 35 | |||
| 36 | exit 0 | ||
diff --git a/test/json1.test b/test/json1.test new file mode 100755 index 0000000..dba4912 --- /dev/null +++ b/test/json1.test | |||
| @@ -0,0 +1,19 @@ | |||
| 1 | ## -*- sh -*- | ||
| 2 | |||
| 3 | set -e | ||
| 4 | |||
| 5 | DATASRC=$top_srcdir/test/data | ||
| 6 | DATAOUT=$top_builddir/test/data | ||
| 7 | TESTFILE=j1.plist | ||
| 8 | |||
| 9 | if ! test -d "$DATAOUT"; then | ||
| 10 | mkdir -p $DATAOUT | ||
| 11 | fi | ||
| 12 | |||
| 13 | export PLIST_JSON_DEBUG=1 | ||
| 14 | |||
| 15 | echo "Converting" | ||
| 16 | $top_builddir/test/plist_jtest $DATASRC/$TESTFILE $DATAOUT/$TESTFILE.out | ||
| 17 | |||
| 18 | echo "Comparing" | ||
| 19 | $top_builddir/test/plist_cmp $DATASRC/$TESTFILE $DATAOUT/$TESTFILE.out | ||
diff --git a/test/json2.test b/test/json2.test new file mode 100755 index 0000000..06a7007 --- /dev/null +++ b/test/json2.test | |||
| @@ -0,0 +1,22 @@ | |||
| 1 | ## -*- sh -*- | ||
| 2 | |||
| 3 | set -e | ||
| 4 | |||
| 5 | DATASRC=$top_srcdir/test/data | ||
| 6 | DATAOUT=$top_builddir/test/data | ||
| 7 | TESTFILE=entities.plist | ||
| 8 | |||
| 9 | if ! test -d "$DATAOUT"; then | ||
| 10 | mkdir -p $DATAOUT | ||
| 11 | fi | ||
| 12 | |||
| 13 | export PLIST_JSON_DEBUG=1 | ||
| 14 | |||
| 15 | echo "Converting input file to JSON" | ||
| 16 | $top_builddir/tools/plistutil -f json -i $DATASRC/$TESTFILE -o $DATASRC/$TESTFILE.json | ||
| 17 | |||
| 18 | echo "Converting to binary and back to JSON" | ||
| 19 | $top_builddir/test/plist_jtest $DATASRC/$TESTFILE.json $DATAOUT/$TESTFILE.json.out | ||
| 20 | |||
| 21 | echo "Comparing" | ||
| 22 | $top_builddir/test/plist_cmp $DATASRC/$TESTFILE $DATAOUT/$TESTFILE.json.out | ||
diff --git a/test/malformed_dict.test b/test/malformed_dict.test index f45ae7e..cbad2bd 100755 --- a/test/malformed_dict.test +++ b/test/malformed_dict.test | |||
| @@ -1,7 +1,5 @@ | |||
| 1 | ## -*- sh -*- | 1 | ## -*- sh -*- |
| 2 | 2 | ||
| 3 | set -e | ||
| 4 | |||
| 5 | DATASRC=$top_srcdir/test/data | 3 | DATASRC=$top_srcdir/test/data |
| 6 | TESTFILE=malformed_dict.bplist | 4 | TESTFILE=malformed_dict.bplist |
| 7 | DATAIN0=$DATASRC/$TESTFILE | 5 | DATAIN0=$DATASRC/$TESTFILE |
| @@ -9,3 +7,9 @@ DATAOUT0=$top_builddir/test/data/$TESTFILE.out | |||
| 9 | 7 | ||
| 10 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 | 8 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 |
| 11 | 9 | ||
| 10 | # test succeeds if plistutil fails | ||
| 11 | if [ $? -eq 0 ]; then | ||
| 12 | exit 1 | ||
| 13 | else | ||
| 14 | exit 0 | ||
| 15 | fi | ||
diff --git a/test/plist_cmp.c b/test/plist_cmp.c index c854446..85b92ee 100644 --- a/test/plist_cmp.c +++ b/test/plist_cmp.c | |||
| @@ -126,11 +126,15 @@ int main(int argc, char *argv[]) | |||
| 126 | 126 | ||
| 127 | if (memcmp(plist_1, "bplist00", 8) == 0) | 127 | if (memcmp(plist_1, "bplist00", 8) == 0) |
| 128 | plist_from_bin(plist_1, size_in1, &root_node1); | 128 | plist_from_bin(plist_1, size_in1, &root_node1); |
| 129 | else if (plist_1[0] == '[' || plist_1[0] == '{') | ||
| 130 | plist_from_json(plist_1, size_in1, &root_node1); | ||
| 129 | else | 131 | else |
| 130 | plist_from_xml(plist_1, size_in1, &root_node1); | 132 | plist_from_xml(plist_1, size_in1, &root_node1); |
| 131 | 133 | ||
| 132 | if (memcmp(plist_2, "bplist00", 8) == 0) | 134 | if (memcmp(plist_2, "bplist00", 8) == 0) |
| 133 | plist_from_bin(plist_2, size_in2, &root_node2); | 135 | plist_from_bin(plist_2, size_in2, &root_node2); |
| 136 | else if (plist_2[0] == '[' || plist_2[0] == '{') | ||
| 137 | plist_from_json(plist_2, size_in2, &root_node2); | ||
| 134 | else | 138 | else |
| 135 | plist_from_xml(plist_2, size_in2, &root_node2); | 139 | plist_from_xml(plist_2, size_in2, &root_node2); |
| 136 | 140 | ||
diff --git a/test/plist_jtest.c b/test/plist_jtest.c new file mode 100644 index 0000000..130e3c7 --- /dev/null +++ b/test/plist_jtest.c | |||
| @@ -0,0 +1,131 @@ | |||
| 1 | /* | ||
| 2 | * backup_test.c | ||
| 3 | * source libplist regression test | ||
| 4 | * | ||
| 5 | * Copyright (c) 2009 Jonathan Beck All Rights Reserved. | ||
| 6 | * | ||
| 7 | * This library is free software; you can redistribute it and/or | ||
| 8 | * modify it under the terms of the GNU Lesser General Public | ||
| 9 | * License as published by the Free Software Foundation; either | ||
| 10 | * version 2.1 of the License, or (at your option) any later version. | ||
| 11 | * | ||
| 12 | * This library is distributed in the hope that it will be useful, | ||
| 13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 15 | * Lesser General Public License for more details. | ||
| 16 | * | ||
| 17 | * You should have received a copy of the GNU Lesser General Public | ||
| 18 | * License along with this library; if not, write to the Free Software | ||
| 19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | ||
| 20 | */ | ||
| 21 | |||
| 22 | |||
| 23 | #include "plist/plist.h" | ||
| 24 | |||
| 25 | #include <stdio.h> | ||
| 26 | #include <stdlib.h> | ||
| 27 | #include <string.h> | ||
| 28 | #include <sys/stat.h> | ||
| 29 | |||
| 30 | #ifdef _MSC_VER | ||
| 31 | #pragma warning(disable:4996) | ||
| 32 | #endif | ||
| 33 | |||
| 34 | |||
| 35 | int main(int argc, char *argv[]) | ||
| 36 | { | ||
| 37 | FILE *iplist = NULL; | ||
| 38 | plist_t root_node1 = NULL; | ||
| 39 | plist_t root_node2 = NULL; | ||
| 40 | char *plist_json = NULL; | ||
| 41 | char *plist_json2 = NULL; | ||
| 42 | char *plist_bin = NULL; | ||
| 43 | int size_in = 0; | ||
| 44 | uint32_t size_out = 0; | ||
| 45 | uint32_t size_out2 = 0; | ||
| 46 | char *file_in = NULL; | ||
| 47 | char *file_out = NULL; | ||
| 48 | struct stat *filestats = (struct stat *) malloc(sizeof(struct stat)); | ||
| 49 | if (argc != 3) | ||
| 50 | { | ||
| 51 | printf("Wrong input\n"); | ||
| 52 | return 1; | ||
| 53 | } | ||
| 54 | |||
| 55 | file_in = argv[1]; | ||
| 56 | file_out = argv[2]; | ||
| 57 | //read input file | ||
| 58 | iplist = fopen(file_in, "rb"); | ||
| 59 | |||
| 60 | if (!iplist) | ||
| 61 | { | ||
| 62 | printf("File does not exists\n"); | ||
| 63 | return 2; | ||
| 64 | } | ||
| 65 | printf("File %s is open\n", file_in); | ||
| 66 | stat(file_in, filestats); | ||
| 67 | size_in = filestats->st_size; | ||
| 68 | plist_json = (char *) malloc(sizeof(char) * (size_in + 1)); | ||
| 69 | fread(plist_json, sizeof(char), size_in, iplist); | ||
| 70 | fclose(iplist); | ||
| 71 | plist_json[size_in] = 0; | ||
| 72 | |||
| 73 | //convert one format to another | ||
| 74 | plist_from_json(plist_json, size_in, &root_node1); | ||
| 75 | if (!root_node1) | ||
| 76 | { | ||
| 77 | printf("PList JSON parsing failed\n"); | ||
| 78 | return 3; | ||
| 79 | } | ||
| 80 | |||
| 81 | printf("PList JSON parsing succeeded\n"); | ||
| 82 | plist_to_bin(root_node1, &plist_bin, &size_out); | ||
| 83 | if (!plist_bin) | ||
| 84 | { | ||
| 85 | printf("PList BIN writing failed\n"); | ||
| 86 | return 4; | ||
| 87 | } | ||
| 88 | |||
| 89 | printf("PList BIN writing succeeded\n"); | ||
| 90 | plist_from_bin(plist_bin, size_out, &root_node2); | ||
| 91 | if (!root_node2) | ||
| 92 | { | ||
| 93 | printf("PList BIN parsing failed\n"); | ||
| 94 | return 5; | ||
| 95 | } | ||
| 96 | |||
| 97 | printf("PList BIN parsing succeeded\n"); | ||
| 98 | plist_to_json(root_node2, &plist_json2, &size_out2, 0); | ||
| 99 | if (!plist_json2) | ||
| 100 | { | ||
| 101 | printf("PList JSON writing failed\n"); | ||
| 102 | return 8; | ||
| 103 | } | ||
| 104 | |||
| 105 | printf("PList JSON writing succeeded\n"); | ||
| 106 | if (plist_json2) | ||
| 107 | { | ||
| 108 | FILE *oplist = NULL; | ||
| 109 | oplist = fopen(file_out, "wb"); | ||
| 110 | fwrite(plist_json2, size_out2, sizeof(char), oplist); | ||
| 111 | fclose(oplist); | ||
| 112 | } | ||
| 113 | |||
| 114 | plist_free(root_node1); | ||
| 115 | plist_free(root_node2); | ||
| 116 | free(plist_bin); | ||
| 117 | free(plist_json); | ||
| 118 | free(plist_json2); | ||
| 119 | free(filestats); | ||
| 120 | |||
| 121 | if ((uint32_t)size_in != size_out2) | ||
| 122 | { | ||
| 123 | printf("Size of input and output is different\n"); | ||
| 124 | printf("Input size : %i\n", size_in); | ||
| 125 | printf("Output size : %i\n", size_out2); | ||
| 126 | } | ||
| 127 | |||
| 128 | //success | ||
| 129 | return 0; | ||
| 130 | } | ||
| 131 | |||
diff --git a/test/recursion.test b/test/recursion.test index 0120a12..9946d81 100755 --- a/test/recursion.test +++ b/test/recursion.test | |||
| @@ -1,7 +1,5 @@ | |||
| 1 | ## -*- sh -*- | 1 | ## -*- sh -*- |
| 2 | 2 | ||
| 3 | set -e | ||
| 4 | |||
| 5 | DATASRC=$top_srcdir/test/data | 3 | DATASRC=$top_srcdir/test/data |
| 6 | TESTFILE=recursion.bplist | 4 | TESTFILE=recursion.bplist |
| 7 | DATAIN0=$DATASRC/$TESTFILE | 5 | DATAIN0=$DATASRC/$TESTFILE |
| @@ -9,3 +7,9 @@ DATAOUT0=$top_builddir/test/data/$TESTFILE.out | |||
| 9 | 7 | ||
| 10 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 | 8 | $top_builddir/tools/plistutil -i $DATAIN0 -o $DATAOUT0 |
| 11 | 9 | ||
| 10 | # test succeeds if plistutil fails | ||
| 11 | if [ $? -eq 0 ]; then | ||
| 12 | exit 1 | ||
| 13 | else | ||
| 14 | exit 0 | ||
| 15 | fi | ||
