Be more efficient when polling for build status in the repo view
This commit is contained in:
parent
d4b9ebf4b9
commit
2128e39d77
1 changed files with 21 additions and 1 deletions
|
@ -75,7 +75,7 @@
|
||||||
loadImages();
|
loadImages();
|
||||||
|
|
||||||
// Track builds.
|
// Track builds.
|
||||||
buildPollChannel = AngularPollChannel.create($scope, loadRepositoryBuilds, 5000 /* 5s */);
|
buildPollChannel = AngularPollChannel.create($scope, loadRepositoryBuilds, 15000 /* 15s */);
|
||||||
buildPollChannel.start();
|
buildPollChannel.start();
|
||||||
}, 10);
|
}, 10);
|
||||||
});
|
});
|
||||||
|
@ -102,6 +102,26 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
$scope.repositoryBuildsResource = ApiService.getRepoBuildsAsResource(params, /* background */true).get(function(resp) {
|
$scope.repositoryBuildsResource = ApiService.getRepoBuildsAsResource(params, /* background */true).get(function(resp) {
|
||||||
|
// Note: We could just set the builds here, but that causes a full digest cycle. Therefore,
|
||||||
|
// to be more efficient, we do some work here to determine if anything has changed since
|
||||||
|
// the last build load in the common case.
|
||||||
|
if ($scope.viewScope.builds && resp.builds.length == $scope.viewScope.builds.length) {
|
||||||
|
var hasNewInformation = false;
|
||||||
|
for (var i = 0; i < resp.builds.length; ++i) {
|
||||||
|
var current = $scope.viewScope.builds[i];
|
||||||
|
var updated = resp.builds[i];
|
||||||
|
if (current.phase != updated.phase || current.id != updated.id) {
|
||||||
|
hasNewInformation = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!hasNewInformation) {
|
||||||
|
callback(true);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$scope.viewScope.builds = resp.builds;
|
$scope.viewScope.builds = resp.builds;
|
||||||
callback(true);
|
callback(true);
|
||||||
}, errorHandler);
|
}, errorHandler);
|
||||||
|
|
Reference in a new issue