1*543adbedSBen Gras /*-
2*543adbedSBen Gras * Copyright (c) 2003-2007 Tim Kientzle
3*543adbedSBen Gras * All rights reserved.
4*543adbedSBen Gras *
5*543adbedSBen Gras * Redistribution and use in source and binary forms, with or without
6*543adbedSBen Gras * modification, are permitted provided that the following conditions
7*543adbedSBen Gras * are met:
8*543adbedSBen Gras * 1. Redistributions of source code must retain the above copyright
9*543adbedSBen Gras * notice, this list of conditions and the following disclaimer.
10*543adbedSBen Gras * 2. Redistributions in binary form must reproduce the above copyright
11*543adbedSBen Gras * notice, this list of conditions and the following disclaimer in the
12*543adbedSBen Gras * documentation and/or other materials provided with the distribution.
13*543adbedSBen Gras *
14*543adbedSBen Gras * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
15*543adbedSBen Gras * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16*543adbedSBen Gras * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17*543adbedSBen Gras * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
18*543adbedSBen Gras * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19*543adbedSBen Gras * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20*543adbedSBen Gras * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21*543adbedSBen Gras * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22*543adbedSBen Gras * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23*543adbedSBen Gras * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24*543adbedSBen Gras */
25*543adbedSBen Gras #include "test.h"
26*543adbedSBen Gras __FBSDID("$FreeBSD$");
27*543adbedSBen Gras
28*543adbedSBen Gras /*
29*543adbedSBen Gras * Test that --version option works and generates reasonable output.
30*543adbedSBen Gras */
31*543adbedSBen Gras
32*543adbedSBen Gras static void
verify(const char * p,size_t s)33*543adbedSBen Gras verify(const char *p, size_t s)
34*543adbedSBen Gras {
35*543adbedSBen Gras const char *q = p;
36*543adbedSBen Gras
37*543adbedSBen Gras /* Version message should start with name of program, then space. */
38*543adbedSBen Gras failure("version message too short:", p);
39*543adbedSBen Gras if (!assert(s > 6))
40*543adbedSBen Gras return;
41*543adbedSBen Gras failure("Version message should begin with 'bsdcpio': %s", p);
42*543adbedSBen Gras if (!assertEqualMem(q, "bsdcpio ", 8))
43*543adbedSBen Gras /* If we're not testing bsdcpio, don't keep going. */
44*543adbedSBen Gras return;
45*543adbedSBen Gras q += 8; s -= 8;
46*543adbedSBen Gras /* Version number is a series of digits and periods. */
47*543adbedSBen Gras while (s > 0 && (*q == '.' || (*q >= '0' && *q <= '9'))) {
48*543adbedSBen Gras ++q;
49*543adbedSBen Gras --s;
50*543adbedSBen Gras }
51*543adbedSBen Gras /* Version number terminated by space. */
52*543adbedSBen Gras failure("Version: %s", p);
53*543adbedSBen Gras assert(s > 1);
54*543adbedSBen Gras /* Skip a single trailing a,b,c, or d. */
55*543adbedSBen Gras if (*q == 'a' || *q == 'b' || *q == 'c' || *q == 'd')
56*543adbedSBen Gras ++q;
57*543adbedSBen Gras failure("Version: %s", p);
58*543adbedSBen Gras assert(*q == ' ');
59*543adbedSBen Gras ++q; --s;
60*543adbedSBen Gras /* Separator. */
61*543adbedSBen Gras failure("Version: %s", p);
62*543adbedSBen Gras assertEqualMem(q, "-- ", 3);
63*543adbedSBen Gras q += 3; s -= 3;
64*543adbedSBen Gras /* libarchive name and version number */
65*543adbedSBen Gras assert(s > 11);
66*543adbedSBen Gras failure("Version: %s", p);
67*543adbedSBen Gras assertEqualMem(q, "libarchive ", 11);
68*543adbedSBen Gras q += 11; s -= 11;
69*543adbedSBen Gras /* Version number is a series of digits and periods. */
70*543adbedSBen Gras while (s > 0 && (*q == '.' || (*q >= '0' && *q <= '9'))) {
71*543adbedSBen Gras ++q;
72*543adbedSBen Gras --s;
73*543adbedSBen Gras }
74*543adbedSBen Gras /* Skip a single trailing a,b,c, or d. */
75*543adbedSBen Gras if (*q == 'a' || *q == 'b' || *q == 'c' || *q == 'd')
76*543adbedSBen Gras ++q;
77*543adbedSBen Gras /* All terminated by end-of-line: \r, \r\n, or \n */
78*543adbedSBen Gras assert(s >= 1);
79*543adbedSBen Gras failure("Version: %s", p);
80*543adbedSBen Gras if (*q == '\x0d') {
81*543adbedSBen Gras if (q[1] != '\0')
82*543adbedSBen Gras assertEqualMem(q, "\x0d\x0a", 2);
83*543adbedSBen Gras } else
84*543adbedSBen Gras assertEqualMem(q, "\x0a", 1);
85*543adbedSBen Gras }
86*543adbedSBen Gras
87*543adbedSBen Gras
DEFINE_TEST(test_option_version)88*543adbedSBen Gras DEFINE_TEST(test_option_version)
89*543adbedSBen Gras {
90*543adbedSBen Gras int r;
91*543adbedSBen Gras char *p;
92*543adbedSBen Gras size_t s;
93*543adbedSBen Gras
94*543adbedSBen Gras r = systemf("%s --version >version.stdout 2>version.stderr", testprog);
95*543adbedSBen Gras if (r != 0)
96*543adbedSBen Gras r = systemf("%s -W version >version.stdout 2>version.stderr",
97*543adbedSBen Gras testprog);
98*543adbedSBen Gras failure("Unable to run either %s --version or %s -W version",
99*543adbedSBen Gras testprog, testprog);
100*543adbedSBen Gras if (!assert(r == 0))
101*543adbedSBen Gras return;
102*543adbedSBen Gras
103*543adbedSBen Gras /* --version should generate nothing to stderr. */
104*543adbedSBen Gras assertEmptyFile("version.stderr");
105*543adbedSBen Gras /* Verify format of version message. */
106*543adbedSBen Gras p = slurpfile(&s, "version.stdout");
107*543adbedSBen Gras verify(p, s);
108*543adbedSBen Gras free(p);
109*543adbedSBen Gras }
110