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: src/usr.bin/tar/test/test_version.c,v 1.2 2008/05/26 17:10:10 kientzle Exp $");
27*543adbedSBen Gras
28*543adbedSBen Gras /*
29*543adbedSBen Gras * Test that --version option works and generates reasonable output.
30*543adbedSBen Gras */
31*543adbedSBen Gras
DEFINE_TEST(test_version)32*543adbedSBen Gras DEFINE_TEST(test_version)
33*543adbedSBen Gras {
34*543adbedSBen Gras int r;
35*543adbedSBen Gras char *p, *q;
36*543adbedSBen Gras size_t s;
37*543adbedSBen Gras
38*543adbedSBen Gras
39*543adbedSBen Gras r = systemf("%s --version >version.stdout 2>version.stderr", testprog);
40*543adbedSBen Gras if (r != 0)
41*543adbedSBen Gras r = systemf("%s -W version >version.stdout 2>version.stderr",
42*543adbedSBen Gras testprog);
43*543adbedSBen Gras failure("Unable to run either %s --version or %s -W version",
44*543adbedSBen Gras testprog, testprog);
45*543adbedSBen Gras if (!assert(r == 0))
46*543adbedSBen Gras return;
47*543adbedSBen Gras
48*543adbedSBen Gras /* --version should generate nothing to stdout. */
49*543adbedSBen Gras assertEmptyFile("version.stderr");
50*543adbedSBen Gras /* Verify format of version message. */
51*543adbedSBen Gras q = p = slurpfile(&s, "version.stdout");
52*543adbedSBen Gras /* Version message should start with name of program, then space. */
53*543adbedSBen Gras assert(s > 6);
54*543adbedSBen Gras failure("Version must start with 'bsdtar': ``%s''", p);
55*543adbedSBen Gras if (!assertEqualMem(q, "bsdtar ", 7))
56*543adbedSBen Gras return;
57*543adbedSBen Gras q += 7; s -= 7;
58*543adbedSBen Gras /* Version number is a series of digits and periods. */
59*543adbedSBen Gras while (s > 0 && (*q == '.' || (*q >= '0' && *q <= '9'))) {
60*543adbedSBen Gras ++q;
61*543adbedSBen Gras --s;
62*543adbedSBen Gras }
63*543adbedSBen Gras /* Version number terminated by space. */
64*543adbedSBen Gras failure("No space after bsdtar version: ``%s''", p);
65*543adbedSBen Gras assert(s > 1);
66*543adbedSBen Gras /* Skip a single trailing a,b,c, or d. */
67*543adbedSBen Gras if (*q == 'a' || *q == 'b' || *q == 'c' || *q == 'd')
68*543adbedSBen Gras ++q;
69*543adbedSBen Gras failure("No space after bsdtar version: ``%s''", p);
70*543adbedSBen Gras assert(*q == ' ');
71*543adbedSBen Gras ++q; --s;
72*543adbedSBen Gras /* Separator. */
73*543adbedSBen Gras failure("No `-' between bsdtar and libarchive versions: ``%s''", p);
74*543adbedSBen Gras assertEqualMem(q, "- ", 2);
75*543adbedSBen Gras q += 2; s -= 2;
76*543adbedSBen Gras /* libarchive name and version number */
77*543adbedSBen Gras failure("Not long enough for libarchive version: ``%s''", p);
78*543adbedSBen Gras assert(s > 11);
79*543adbedSBen Gras failure("Libarchive version must start with `libarchive': ``%s''", p);
80*543adbedSBen Gras assertEqualMem(q, "libarchive ", 11);
81*543adbedSBen Gras q += 11; s -= 11;
82*543adbedSBen Gras /* Version number is a series of digits and periods. */
83*543adbedSBen Gras while (s > 0 && (*q == '.' || (*q >= '0' && *q <= '9'))) {
84*543adbedSBen Gras ++q;
85*543adbedSBen Gras --s;
86*543adbedSBen Gras }
87*543adbedSBen Gras /* Skip a single trailing a,b,c, or d. */
88*543adbedSBen Gras if (*q == 'a' || *q == 'b' || *q == 'c' || *q == 'd')
89*543adbedSBen Gras ++q;
90*543adbedSBen Gras /* All terminated by end-of-line. */
91*543adbedSBen Gras assert(s >= 1);
92*543adbedSBen Gras /* Skip an optional CR character (e.g., Windows) */
93*543adbedSBen Gras failure("Version output must end with \\n or \\r\\n");
94*543adbedSBen Gras if (*q == '\r') { ++q; --s; }
95*543adbedSBen Gras assertEqualMem(q, "\n", 1);
96*543adbedSBen Gras free(p);
97*543adbedSBen Gras }
98