]> nos-oignons.net Git - gestion-adh.git/blobdiff - features/step_definitions/git.rb
Release the code under AGPLv3 and add missing copyright information
[gestion-adh.git] / features / step_definitions / git.rb
index 27d22a7ee1afcac3b118eee0b7afe0a1aa9e2a3b..abd3e765615288000ab436d436cde368f4d02b88 100644 (file)
@@ -1,22 +1,42 @@
+#-*- coding: utf-8 -*-
+#
+# Système de gestion des adhésions de Nos oignons
+# Copyright © 2013-2014 Nos oignons <contact@nos-oignons.net>
+#
+# 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 <http://www.gnu.org/licenses/>.
+
 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