#!/usr/local/bin/perl -w =head1 NAME t/99p4_label_branch_rev_1.t =cut use strict ; use Carp ; use File::Basename; use Test ; use VCP::Dest::p4; use VCP::Logger qw( set_quiet_mode ); use VCP::Source::null; use VCP::TestUtils; set_quiet_mode( 1 ); my $progname = basename $0; my $t = -d 't' ? 't/' : '' ; my $p4root = tmpdir "p4root"; my $dest = VCP::Dest::p4->new( "p4:$progname\@$p4root://depot/...", [qw( --init-p4d --delete-p4d-dir )] ); my $source = VCP::Source::null->new; my $change_id = 1; sub p4_r { my ( $action, $name, $rev_id, $previous_id, $labels ) = @_; my $r = VCP::Rev->new( action => $action, name => $name, source_name => $name, rev_id => $rev_id, source_rev_id => $rev_id, type => "text", time => 0+time, source_repo_id => $progname, source => $source, source_filebranch_id => "/depot/$name", branch_id => "/depot", previous_id => $previous_id, change_id => $change_id, ); $r->set_labels( @$labels ) if $labels; $r->set_source( $source ); return $r; } my @tests = ( sub { $dest->init; $dest->handle_header( { rep_type => "test", rev_root => "//depot", } ); $dest->handle_rev( p4_r qw( edit foo 1 ) ); ++$change_id; $dest->handle_rev( p4_r qw( branch bar 1 ), "foo#1", [ qw( uh_oh_label ) ] ); $dest->handle_footer(); ok 1; }, sub { $dest->p4( [ "filelog", "//...\@uh_oh_label" ], undef, \my $out ); ok $out, qr{//depot/bar}; }, ) ; plan tests => scalar @tests ; my $why_skip ; $why_skip .= p4_borken; $why_skip .= p4d_borken; $why_skip ? skip( $why_skip, '' ) : $_->() for @tests ; ## This normally happens at END{} time, but VCP::TestUtils' END{} ## runs first and complains because it can't rmtree() the tmpdir ## that p4d is running in, so kill it thusly. $dest = undef; VCP::Utils::p4->_cleanup_p4;
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#1 | 6118 | Dimitry Andric | Integ from //public/revml to //guest/dimitry_andric/revml/main. | ||
//guest/perforce_software/revml/t/99p4_label_branch_rev_1.t | |||||
#4 | 5403 | Barrie Slaymaker | - Misc logging, maintainability & debugging improvements | ||
#3 | 4471 | Barrie Slaymaker | - All tests now pass on Win32 | ||
#2 | 4166 | Barrie Slaymaker | - No more VCP::Dest::p4 BUG on labelling a freshly branch file | ||
#1 | 4165 | Barrie Slaymaker |
- VCP::Source::null now returns /dev/null or NUL for files - VCP::Dest::p4 now watches is_branch_rev() to detect branches - t/99p4_label_branch_rev_1.t reproduces a bug reported by Matt Attaway < matt at perforce com > |