X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/8bbb07a1bc5db944ba95fa5951ed40c3c1b968aa..f3e83e558e53c812ce48784b950d0309eb8da3bb:/features/step_definitions/git.rb diff --git a/features/step_definitions/git.rb b/features/step_definitions/git.rb index 27d22a7..abd3e76 100644 --- a/features/step_definitions/git.rb +++ b/features/step_definitions/git.rb @@ -1,22 +1,42 @@ +#-*- coding: utf-8 -*- +# +# Système de gestion des adhésions de Nos oignons +# Copyright © 2013-2014 Nos oignons +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as +# published by the Free Software Foundation, either version 3 of the +# License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see . + 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 +44,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