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 * Also see test_option_q for additional validation of -r support.
30*543adbedSBen Gras */
DEFINE_TEST(test_option_r)31*543adbedSBen Gras DEFINE_TEST(test_option_r)
32*543adbedSBen Gras {
33*543adbedSBen Gras char buff[15];
34*543adbedSBen Gras char *p0, *p1;
35*543adbedSBen Gras size_t s;
36*543adbedSBen Gras FILE *f;
37*543adbedSBen Gras int r;
38*543adbedSBen Gras
39*543adbedSBen Gras /* Create a file */
40*543adbedSBen Gras f = fopen("f1", "w");
41*543adbedSBen Gras if (!assert(f != NULL))
42*543adbedSBen Gras return;
43*543adbedSBen Gras assertEqualInt(3, fwrite("abc", 1, 3, f));
44*543adbedSBen Gras fclose(f);
45*543adbedSBen Gras
46*543adbedSBen Gras /* Archive that one file. */
47*543adbedSBen Gras r = systemf("%s cf archive.tar --format=ustar f1 >step1.out 2>step1.err", testprog);
48*543adbedSBen Gras failure("Error invoking %s cf archive.tar f1", testprog);
49*543adbedSBen Gras assertEqualInt(r, 0);
50*543adbedSBen Gras
51*543adbedSBen Gras /* Verify that nothing went to stdout or stderr. */
52*543adbedSBen Gras assertEmptyFile("step1.out");
53*543adbedSBen Gras assertEmptyFile("step1.err");
54*543adbedSBen Gras
55*543adbedSBen Gras
56*543adbedSBen Gras /* Do some basic validation of the constructed archive. */
57*543adbedSBen Gras p0 = slurpfile(&s, "archive.tar");
58*543adbedSBen Gras if (!assert(p0 != NULL))
59*543adbedSBen Gras return;
60*543adbedSBen Gras if (!assert(s >= 2048)) {
61*543adbedSBen Gras free(p0);
62*543adbedSBen Gras return;
63*543adbedSBen Gras }
64*543adbedSBen Gras assertEqualMem(p0 + 0, "f1", 3);
65*543adbedSBen Gras assertEqualMem(p0 + 512, "abc", 3);
66*543adbedSBen Gras assertEqualMem(p0 + 1024, "\0\0\0\0\0\0\0\0", 8);
67*543adbedSBen Gras assertEqualMem(p0 + 1536, "\0\0\0\0\0\0\0\0", 8);
68*543adbedSBen Gras
69*543adbedSBen Gras /* Edit that file */
70*543adbedSBen Gras f = fopen("f1", "w");
71*543adbedSBen Gras if (!assert(f != NULL))
72*543adbedSBen Gras return;
73*543adbedSBen Gras assertEqualInt(3, fwrite("123", 1, 3, f));
74*543adbedSBen Gras fclose(f);
75*543adbedSBen Gras
76*543adbedSBen Gras /* Update the archive. */
77*543adbedSBen Gras r = systemf("%s rf archive.tar --format=ustar f1 >step2.out 2>step2.err", testprog);
78*543adbedSBen Gras failure("Error invoking %s rf archive.tar f1", testprog);
79*543adbedSBen Gras assertEqualInt(r, 0);
80*543adbedSBen Gras
81*543adbedSBen Gras /* Verify that nothing went to stdout or stderr. */
82*543adbedSBen Gras assertEmptyFile("step2.out");
83*543adbedSBen Gras assertEmptyFile("step2.err");
84*543adbedSBen Gras
85*543adbedSBen Gras /* Do some basic validation of the constructed archive. */
86*543adbedSBen Gras p1 = slurpfile(&s, "archive.tar");
87*543adbedSBen Gras if (!assert(p1 != NULL)) {
88*543adbedSBen Gras free(p0);
89*543adbedSBen Gras return;
90*543adbedSBen Gras }
91*543adbedSBen Gras assert(s >= 3072);
92*543adbedSBen Gras /* Verify first entry is unchanged. */
93*543adbedSBen Gras assertEqualMem(p0, p1, 1024);
94*543adbedSBen Gras /* Verify that second entry is correct. */
95*543adbedSBen Gras assertEqualMem(p1 + 1024, "f1", 3);
96*543adbedSBen Gras assertEqualMem(p1 + 1536, "123", 3);
97*543adbedSBen Gras /* Verify end-of-archive marker. */
98*543adbedSBen Gras assertEqualMem(p1 + 2048, "\0\0\0\0\0\0\0\0", 8);
99*543adbedSBen Gras assertEqualMem(p1 + 2560, "\0\0\0\0\0\0\0\0", 8);
100*543adbedSBen Gras free(p0);
101*543adbedSBen Gras free(p1);
102*543adbedSBen Gras
103*543adbedSBen Gras /* Unpack both items */
104*543adbedSBen Gras assertMakeDir("step3", 0775);
105*543adbedSBen Gras assertChdir("step3");
106*543adbedSBen Gras r = systemf("%s xf ../archive.tar", testprog);
107*543adbedSBen Gras failure("Error invoking %s xf archive.tar", testprog);
108*543adbedSBen Gras assertEqualInt(r, 0);
109*543adbedSBen Gras
110*543adbedSBen Gras /* Verify that the second one overwrote the first. */
111*543adbedSBen Gras f = fopen("f1", "r");
112*543adbedSBen Gras if (assert(f != NULL)) {
113*543adbedSBen Gras assertEqualInt(3, fread(buff, 1, 3, f));
114*543adbedSBen Gras assertEqualMem(buff, "123", 3);
115*543adbedSBen Gras fclose(f);
116*543adbedSBen Gras }
117*543adbedSBen Gras }
118