X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/8bbb07a1bc5db944ba95fa5951ed40c3c1b968aa..9cb7fa95bef77a6d1e0888f741c76adc865f1b17:/features/step_definitions/git.rb diff --git a/features/step_definitions/git.rb b/features/step_definitions/git.rb index 27d22a7..82cc09f 100644 --- a/features/step_definitions/git.rb +++ b/features/step_definitions/git.rb @@ -1,22 +1,26 @@ +#-*- coding: utf-8 -*- + require 'fileutils' Given /^un clone du Git contenant les adhésions$/ do # Create main repository create_dir 'main' cd 'main' - run_simple 'git init' - create_dir 'Membres' - BASE_SUBSCRIPTIONS.each_pair do |number, data| - file = subscription_filename_for_id(number) - write_file file, render_subscription_file(data) - run_simple "git add #{file}" - end - run_simple 'git commit -m "Initial data set from fixtures"' + @main_repository_path = current_dir + run_simple 'git init --quiet --bare' cd '..' # Clone it now - run_simple 'git clone main clone' + run_simple "git clone --quiet --local file://#{current_dir}/main clone" cd 'clone' + create_dir 'Membres' + BASE_MEMBERS.each_pair do |number, data| + file = member_filename_for_id(number) + write_file file, render_member_file(data) + run_simple "git add #{file}" + end + run_simple 'git commit -m "Initial data set from fixtures"' + run_simple 'git push --quiet origin master' end Given /^le « pre-commit hook » correctement configuré$/ do @@ -24,7 +28,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