From 0802559b03cc9f5f383d01926a079b1ef5e9c116 Mon Sep 17 00:00:00 2001 From: Rob Vermaas Date: Wed, 28 Jul 2010 12:48:29 +0000 Subject: [PATCH] hydra: do not perform git clone every time. in stead work on local clone and pull --- release.nix | 2 +- src/lib/Hydra/Helper/AddBuilds.pm | 61 +++++++++++++++---------------- src/sql/hydra.sql | 2 - 3 files changed, 30 insertions(+), 35 deletions(-) diff --git a/release.nix b/release.nix index 8360c394..ae963476 100644 --- a/release.nix +++ b/release.nix @@ -1,4 +1,4 @@ -{ nixpkgs ? ../nixpkgs +{ nixpkgs ? /etc/nixos/nixpkgs , hydraSrc ? {outPath = ./.; rev = 1234;} , officialRelease ? false }: diff --git a/src/lib/Hydra/Helper/AddBuilds.pm b/src/lib/Hydra/Helper/AddBuilds.pm index f0555749..977b92f9 100644 --- a/src/lib/Hydra/Helper/AddBuilds.pm +++ b/src/lib/Hydra/Helper/AddBuilds.pm @@ -12,6 +12,9 @@ use File::Path; our @ISA = qw(Exporter); our @EXPORT = qw(fetchInput evalJobs checkBuild inputsToArgs captureStdoutStderr); +sub scmPath { + return getHydraPath . "/scm" ; +} sub getStorePathHash { my ($storePath) = @_; @@ -275,11 +278,26 @@ sub fetchInputGit { my $sha256; my $storePath; - # First figure out the last-modified revision of the URI. + my $clonePath; + mkpath(scmPath); + $clonePath = scmPath . "/" . sha256_hex($uri); + my $stdout; my $stderr; + if (! -d $clonePath) { + (my $res, $stdout, $stderr) = captureStdoutStderr(600, + ("git", "clone", $uri, $clonePath)); + die "Error cloning git repo at `$uri':\n$stderr" unless $res; + } + + # git pull + check rev + chdir $clonePath or die $!; (my $res, $stdout, $stderr) = captureStdoutStderr(600, - ("git", "ls-remote", $uri, "refs/heads/".$branch)); - die "Cannot get head revision of Git branch '$branch' at `$uri':\n$stderr" unless $res; + ("git", "pull")); + die "Error pulling latest change git repo at `$uri':\n$stderr" unless $res; + + (my $res1, $stdout, $stderr) = captureStdoutStderr(600, + ("git", "ls-remote", $clonePath, "refs/heads/".$branch)); + die "Cannot get head revision of Git branch '$branch' at `$uri':\n$stderr" unless $res1; (my $revision, my $ref) = split ' ', $stdout; die unless $revision =~ /^[0-9a-fA-F]+$/; @@ -289,16 +307,10 @@ sub fetchInputGit { ($cachedInput) = $db->resultset('CachedGitInputs')->search( {uri => $uri, branch => $branch, revision => $revision}, {rows => 1}); - if (! defined $cachedInput ) { - ($cachedInput) = $db->resultset('CachedGitInputs')->search( - {uri => $uri, branch => $branch, lastseen => {">", $timestamp - 3600}}, - {rows => 1, order_by => "lastseen DESC"}); - } if (defined $cachedInput && isValidPath($cachedInput->storepath)) { $storePath = $cachedInput->storepath; $sha256 = $cachedInput->sha256hash; - $timestamp = $cachedInput->timestamp; $revision = $cachedInput->revision; } else { @@ -324,27 +336,16 @@ sub fetchInputGit { die "Cannot check out Git repository branch '$branch' at `$uri':\n$stderr" unless $res; ($sha256, $storePath) = split ' ', $stdout; - ($cachedInput) = $db->resultset('CachedGitInputs')->search( - {uri => $uri, branch => $branch, sha256hash => $sha256}); - if (!defined $cachedInput) { - txn_do($db, sub { - $db->resultset('CachedGitInputs')->update_or_create( - { uri => $uri - , branch => $branch - , revision => $revision - , timestamp => $timestamp - , lastseen => $timestamp - , sha256hash => $sha256 - , storepath => $storePath - }); + txn_do($db, sub { + $db->resultset('CachedGitInputs')->update_or_create( + { uri => $uri + , branch => $branch + , revision => $revision + , sha256hash => $sha256 + , storepath => $storePath }); - } else { - $timestamp = $cachedInput->timestamp; - txn_do($db, sub { - $cachedInput->update({lastseen => time}); }); - } } return @@ -356,10 +357,6 @@ sub fetchInputGit { }; } -sub scmPath { - return getHydraPath . "/scm" ; -} - sub fetchInputHg { my ($db, $project, $jobset, $name, $type, $value) = @_; @@ -387,7 +384,7 @@ sub fetchInputHg { (my $res1, $stdout, $stderr) = captureStdoutStderr(600, ("hg", "heads", $branch)); - die "Error getting head of $branch from `$uri':\n$stderr" unless $res; + die "Error getting head of $branch from `$uri':\n$stderr" unless $res1; $stdout =~ m/[0-9]+:([0-9A-Fa-f]{12})/; my $revision = $1; diff --git a/src/sql/hydra.sql b/src/sql/hydra.sql index 5be50c56..5c5e69b4 100644 --- a/src/sql/hydra.sql +++ b/src/sql/hydra.sql @@ -311,8 +311,6 @@ create table CachedGitInputs ( uri text not null, branch text not null, revision text not null, - timestamp integer not null, -- when we first saw this hash - lastSeen integer not null, -- when we last saw this hash sha256hash text not null, storePath text not null, primary key (uri, branch, revision)