]> nos-oignons.net Git - gestion-adh.git/blobdiff - features/step_definitions/git.rb
Implement pre-receive hook
[gestion-adh.git] / features / step_definitions / git.rb
index 27d22a7ee1afcac3b118eee0b7afe0a1aa9e2a3b..50624ffb3644d8d0f94935a4a64fcc63301dd763 100644 (file)
@@ -4,7 +4,13 @@ Given /^un clone du Git contenant les adhésions$/ do
   # Create main repository
   create_dir 'main'
   cd 'main'
-  run_simple 'git init'
+  @main_repository_path = current_dir
+  run_simple 'git init --bare'
+  cd '..'
+
+  # Clone it now
+  run_simple 'git clone main clone'
+  cd 'clone'
   create_dir 'Membres'
   BASE_SUBSCRIPTIONS.each_pair do |number, data|
     file = subscription_filename_for_id(number)
@@ -12,11 +18,7 @@ Given /^un clone du Git contenant les adhésions$/ do
     run_simple "git add #{file}"
   end
   run_simple 'git commit -m "Initial data set from fixtures"'
-  cd '..'
-
-  # Clone it now
-  run_simple 'git clone main clone'
-  cd 'clone'
+  run_simple 'git push origin master'
 end
 
 Given /^le « pre-commit hook » correctement configuré$/ do
@@ -24,7 +26,18 @@ Given /^le « pre-commit hook » correctement configuré$/ do
                  "#{current_dir}/.git/hooks/pre-commit"
 end
 
+Given /^le « pre-receive hook » configuré sur le dépôt principal$/ do
+  FileUtils.ln_s File.expand_path('../../../bin/pre-receive-hook', __FILE__),
+                 "#{@main_repository_path}/hooks/pre-receive"
+end
+
 When /je fais un `commit` du nouveau fichier$/ do
   run_simple "git add #{@file}"
   run_simple "git commit #{@file} -m 'new file'", false # do not fail on error
 end
+
+When /^que je pousse la modification$/ do
+  run_simple "git add #{@file}"
+  run_simple "git commit #{@file} -m 'new file'"
+  run_simple 'git push origin master', false # do not fail on error
+end