From 482a492ab0ce797fb6ab987441b643924d475adf Mon Sep 17 00:00:00 2001 From: Juan Batiz-Benet <juan@benet.ai> Date: Sun, 10 May 2015 07:53:47 -0400 Subject: [PATCH] travis-ci: make test_all_commits After losing jenkins, it's been difficult to test all commits manually. This commit adds a Makefile target that makes travis do it. Unfortunately, this is way too slow. It takes longer than the allotted 10min. After asking the travis people what to do, someone suggested making sure that each commit is pushed to github independently. This makes travis run CI on every single commit in the PR, and gives us nice status indicators on each one (so we know which ones did not pass). This approach means that we need to push a branch to the repo for each commit in the PR-- otherwise travis may cancel its run if it detects that the branch is no longer there. We could automate this with a bot that essentially does: for each PR: git fetch the PR branch push a branch per commit: <branch>-<commit> for each closed PR: delete all branches with pattern <branch>-<commit> --- Makefile | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Makefile b/Makefile index 68e4b31d0..98fac1d09 100644 --- a/Makefile +++ b/Makefile @@ -61,3 +61,11 @@ test_all_commits: @echo "WARNING: this will 'git rebase --exec'." @test/bin/continueyn GIT_EDITOR=true git rebase -i --exec "make test" origin/master + +test_all_commits_travis: + # these are needed because travis. + # we don't use this yet because it takes way too long. + git config --global user.email "nemo@ipfs.io" + git config --global user.name "IPFS BOT" + git fetch origin master:master + GIT_EDITOR=true git rebase -i --exec "make test" master -- GitLab