+SKIP: {
+ undef $sock;
+ my $d = "$tmpdir/d";
+ mkdir $d or xbail "mkdir $d $!";
+ my $opt = { -C => $d, 2 => \(my $err) };
+ ok(!run_script([qw(-clone -q), "$http/404"], undef, $opt), '404 fails');
+ ok(!-d "$d/404", 'destination not created');
+
+ ok(run_script([qw(-clone -q -C), $d, "$http/t2"], undef, $opt),
+ '-clone succeeds on v2');
+ ok(-f "$d/t2/git/0.git/config", 'epoch cloned');
+
+ # writeBitmaps is the default for bare repos in git 2.22+,
+ # so we may stop setting it ourselves.
+ 0 and is(xqx(['git', "--git-dir=$d/t2/git/0.git", 'config',
+ qw(--bool repack.writeBitmaps)]), "true\n",
+ 'write bitmaps set (via include.path=all.git/config');
+
+ is(xqx(['git', "--git-dir=$d/t2/git/0.git", 'config',
+ qw(include.path)]), "../../all.git/config\n",
+ 'include.path set');
+
+ ok(-s "$d/t2/all.git/objects/info/alternates",
+ 'all.git alternates created');
+ ok(-f "$d/t2/manifest.js.gz", 'manifest saved');
+ ok(!-e "$d/t2/mirror.done", 'no leftover mirror.done');
+ ok(!run_script([qw(-fetch --exit-code -C), "$d/t2"], undef, $opt),
+ '-fetch succeeds w/ manifest.js.gz');
+ is($? >> 8, 127, '--exit-code gave 127');
+ unlike($err, qr/git --git-dir=\S+ fetch/, 'no fetch done w/ manifest');
+ unlink("$d/t2/manifest.js.gz") or xbail "unlink $!";
+ ok(!run_script([qw(-fetch --exit-code -C), "$d/t2"], undef, $opt),
+ '-fetch succeeds w/o manifest.js.gz');
+ is($? >> 8, 127, '--exit-code gave 127');
+ like($err, qr/git --git-dir=\S+ fetch/, 'fetch forced w/o manifest');
+
+ ok(run_script([qw(-clone -q -C), $d, "$http/t1"], undef, $opt),
+ 'cloning v1 works');
+ ok(-d "$d/t1", 'v1 cloned');
+ ok(!-e "$d/t1/mirror.done", 'no leftover file');
+ ok(-f "$d/t1/manifest.js.gz", 'manifest saved');
+ ok(!run_script([qw(-fetch --exit-code -C), "$d/t1"], undef, $opt),
+ 'fetching v1 works');
+ is($? >> 8, 127, '--exit-code gave 127');
+ unlike($err, qr/git --git-dir=\S+ fetch/, 'no fetch done w/ manifest');
+ unlink("$d/t1/manifest.js.gz") or xbail "unlink $!";
+ my $before = [ glob("$d/t1/*") ];
+ ok(!run_script([qw(-fetch --exit-code -C), "$d/t1"], undef, $opt),
+ 'fetching v1 works w/o manifest.js.gz');
+ is($? >> 8, 127, '--exit-code gave 127');
+ unlink("$d/t1/FETCH_HEAD"); # git internal
+ like($err, qr/git --git-dir=\S+ fetch/, 'no fetch done w/ manifest');
+ ok(unlink("$d/t1/manifest.js.gz"), 'manifest created');
+ my $after = [ glob("$d/t1/*") ];
+ is_deeply($before, $after, 'no new files created');
+}
+