1 /*- 2 * Copyright (c) 2012 Michihiro NAKAJIMA 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR 15 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 16 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 17 * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT, 18 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 19 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 20 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 21 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 23 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 24 */ 25 26 #include "test.h" 27 28 #define __LIBARCHIVE_TEST 29 #include "archive_cmdline_private.h" 30 31 DEFINE_TEST(test_archive_cmdline) 32 { 33 struct archive_cmdline *cl; 34 35 /* Command name only. */ 36 assert((cl = __archive_cmdline_allocate()) != NULL); 37 if (cl == NULL) 38 return; 39 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, "gzip")); 40 assertEqualInt(1, cl->argc); 41 assertEqualString("gzip", cl->path); 42 assertEqualString("gzip", cl->argv[0]); 43 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 44 45 assert((cl = __archive_cmdline_allocate()) != NULL); 46 if (cl == NULL) 47 return; 48 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, "gzip ")); 49 assertEqualInt(1, cl->argc); 50 failure("path should not include a space character"); 51 assertEqualString("gzip", cl->path); 52 failure("arg0 should not include a space character"); 53 assertEqualString("gzip", cl->argv[0]); 54 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 55 56 assert((cl = __archive_cmdline_allocate()) != NULL); 57 if (cl == NULL) 58 return; 59 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, 60 "/usr/bin/gzip ")); 61 assertEqualInt(1, cl->argc); 62 failure("path should be a full path"); 63 assertEqualString("/usr/bin/gzip", cl->path); 64 failure("arg0 should not be a full path"); 65 assertEqualString("gzip", cl->argv[0]); 66 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 67 68 /* A command line includes space character. */ 69 assert((cl = __archive_cmdline_allocate()) != NULL); 70 if (cl == NULL) 71 return; 72 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, "\"gzip \"")); 73 assertEqualInt(1, cl->argc); 74 failure("path should include a space character"); 75 assertEqualString("gzip ", cl->path); 76 failure("arg0 should include a space character"); 77 assertEqualString("gzip ", cl->argv[0]); 78 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 79 80 /* A command line includes space character: pattern 2.*/ 81 assert((cl = __archive_cmdline_allocate()) != NULL); 82 if (cl == NULL) 83 return; 84 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, "\"gzip \"x")); 85 assertEqualInt(1, cl->argc); 86 failure("path should include a space character"); 87 assertEqualString("gzip x", cl->path); 88 failure("arg0 should include a space character"); 89 assertEqualString("gzip x", cl->argv[0]); 90 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 91 92 /* A command line includes space character: pattern 3.*/ 93 assert((cl = __archive_cmdline_allocate()) != NULL); 94 if (cl == NULL) 95 return; 96 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, 97 "\"gzip \"x\" s \"")); 98 assertEqualInt(1, cl->argc); 99 failure("path should include a space character"); 100 assertEqualString("gzip x s ", cl->path); 101 failure("arg0 should include a space character"); 102 assertEqualString("gzip x s ", cl->argv[0]); 103 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 104 105 /* A command line includes space character: pattern 4.*/ 106 assert((cl = __archive_cmdline_allocate()) != NULL); 107 if (cl == NULL) 108 return; 109 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, 110 "\"gzip\\\" \"")); 111 assertEqualInt(1, cl->argc); 112 failure("path should include a space character"); 113 assertEqualString("gzip\" ", cl->path); 114 failure("arg0 should include a space character"); 115 assertEqualString("gzip\" ", cl->argv[0]); 116 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 117 118 /* A command name with a argument. */ 119 assert((cl = __archive_cmdline_allocate()) != NULL); 120 if (cl == NULL) 121 return; 122 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, "gzip -d")); 123 assertEqualInt(2, cl->argc); 124 assertEqualString("gzip", cl->path); 125 assertEqualString("gzip", cl->argv[0]); 126 assertEqualString("-d", cl->argv[1]); 127 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 128 129 /* A command name with two arguments. */ 130 assert((cl = __archive_cmdline_allocate()) != NULL); 131 if (cl == NULL) 132 return; 133 assertEqualInt(ARCHIVE_OK, __archive_cmdline_parse(cl, "gzip -d -q")); 134 assertEqualInt(3, cl->argc); 135 assertEqualString("gzip", cl->path); 136 assertEqualString("gzip", cl->argv[0]); 137 assertEqualString("-d", cl->argv[1]); 138 assertEqualString("-q", cl->argv[2]); 139 assertEqualInt(ARCHIVE_OK, __archive_cmdline_free(cl)); 140 } 141