Allow to configure the timeout value for the GitInput plugin in different places.
[?]
Apr 14, 2017, 12:10 AM
34SOPSVFSYMJ4BTJBGREAU4H2LHFWI2GKTGZ6R3B4CTUITMVX35QCDependencies
- [2]
Y55DIQQUSupport using Git revisions as branch names - [3]
7EGUBBRQLock paths in the scm cache - [4]
2XGB45G7only checkout the target branch when topgit is used - [5]
JAH3UPWASupport revision control systems via plugins - [6]
3BTJRSU3GitInput.pm: Don't do a chdir to the Git clone
Change contents
- edit in src/lib/Hydra/Plugin/GitInput.pm at line 11
use Env;use Data::Dumper;my $CONFIG_SECTION = "git-input"; - edit in src/lib/Hydra/Plugin/GitInput.pm at line 16
- replacement in src/lib/Hydra/Plugin/GitInput.pm at line 29
(my $uri, my $branch, my $deepClone) = split ' ', $value;my @parts = split ' ', $value;(my $uri, my $branch, my $deepClone) = @parts; - replacement in src/lib/Hydra/Plugin/GitInput.pm at line 32
return ($uri, $branch, $deepClone);my $options = {};my $start_options = 3;# if deepClone has "=" then is considered an option# and not the enabling of deepCloneif (index($deepClone, "=") != -1) {undef $deepClone;$start_options = 2;}foreach my $option (@parts[$start_options .. $#parts]) {(my $key, my $value) = split('=', $option);$options->{$key} = $value;}return ($uri, $branch, $deepClone, $options);}sub _printIfDebug {my ($msg) = @_;print STDERR "GitInput: $msg" if $ENV{'HYDRA_DEBUG'};}=item _pluginConfig($main_config, $input_name)Read the configuration from the main hydra config file.The configuration is loaded from the "git-input" block.Currently only the "timeout" variable is been looked up in the file.The variables defined directly in the input value will overridethe ones on the configuration file, to define the variablesas an input value use: <name>=<value> without spaces andspecify at least he repo url and branch.<git-input># general timeouttimeout = 400<input-name># specific timeout for a particular input nametimeout = 400</input-name># use quotes when the input name has spaces<"foot with spaces"># specific timeout for a particular input nametimeout = 400</"foo with spaces"></git-input>=cutsub _pluginConfig {my ($main_config, $input_name) = @_;my $cfg = $main_config->{$CONFIG_SECTION};# default valuesmy $values = {timeout => 600,};unless (defined $cfg) {_printIfDebug "Unable to load $CONFIG_SECTION section\n";_printIfDebug "Using default values\n";return $values;} else {_printIfDebug "Parsing plugin configuration: ";_printIfDebug Dumper($cfg);}if (defined $cfg->{$input_name} and %{$cfg->{$input_name}}) {_printIfDebug "Merging sections for $input_name\n";$cfg = {%{$cfg}, %{$cfg->{$input_name}}}; # merge with precedense to the input name}if (exists $cfg->{timeout}) {$values->{timeout} = int($cfg->{timeout});_printIfDebug "Using custom timeout for $input_name:";} else {_printIfDebug "Using default timeout for $input_name:";}_printIfDebug "$values->{timeout}\n";return $values; - replacement in src/lib/Hydra/Plugin/GitInput.pm at line 114
my ($uri, $branch, $deepClone) = _parseValue($value);my ($uri, $branch, $deepClone, $options) = _parseValue($value);my $cfg = _pluginConfig($self->{config}, $name);# give preference to the options from the input valuewhile (my ($opt_name, $opt_value) = each %{$options}) {if ($opt_value =~ /\d+/) {$opt_value = int($opt_value);}$cfg->{$opt_name} = $opt_value;_printIfDebug "'$name': override '$opt_name' with input value: $opt_value\n";} - replacement in src/lib/Hydra/Plugin/GitInput.pm at line 146
$res = run(cmd => ["git", "fetch", "-fu", "origin", "+$branch:$localBranch"], dir => $clonePath, timeout => 600);$res = run(cmd => ["git", "fetch", "-fu", "origin"], dir => $clonePath, timeout => 600) if $res->{status};$res = run(cmd => ["git", "fetch", "-fu", "origin", "+$branch:$localBranch"], dir => $clonePath,timeout => $cfg->{timeout});$res = run(cmd => ["git", "fetch", "-fu", "origin"], dir => $clonePath, timeout => $cfg->{timeout}) if $res->{status}; - replacement in src/lib/Hydra/Plugin/GitInput.pm at line 165
$res = run(cmd => ["tg", "remote", "--populate", "origin"], dir => $clonePath, timeout => 600);$res = run(cmd => ["tg", "remote", "--populate", "origin"], dir => $clonePath, timeout => $cfg->{timeout});