From 9344a4dea0059554e7886f6116b20939d7baaa06 Mon Sep 17 00:00:00 2001 From: Tim Meusel Date: Sat, 13 Oct 2018 11:56:24 +0200 Subject: [PATCH 1/5] modulesync 2.1.0 --- .github/CONTRIBUTING.md | 75 ++++++++++++++++++++++++++++++++--------- .gitignore | 1 - .msync.yml | 2 +- .travis.yml | 8 ++--- Gemfile | 3 +- 5 files changed, 66 insertions(+), 23 deletions(-) diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md index 496a5c03..832578e1 100644 --- a/.github/CONTRIBUTING.md +++ b/.github/CONTRIBUTING.md @@ -12,15 +12,20 @@ By participating in this project you agree to abide by its terms. 1. Create a separate branch for your change. -1. Run the tests. We only take pull requests with passing tests, and - documentation. +1. We only take pull requests with passing tests, and documentation. [travis-ci](http://travis-ci.org) + runs the tests for us. You can also execute them locally. This is explained + in a later section. + +1. Checkout [our docs](https://voxpupuli.org/docs/#reviewing-a-module-pr) we + use to review a module and the [official styleguide](https://puppet.com/docs/puppet/6.0/style_guide.html). + They provide some guidance for new code that might help you before you submit a pull request. 1. Add a test for your change. Only refactoring and documentation changes require no new tests. If you are adding functionality or fixing a bug, please add a test. 1. Squash your commits down into logical components. Make sure to rebase - against the current master. + against our current master. 1. Push the branch to your fork and submit a pull request. @@ -38,7 +43,9 @@ By default the tests use a baseline version of Puppet. If you have Ruby 2.x or want a specific version of Puppet, you must set an environment variable such as: - export PUPPET_VERSION="~> 4.2.0" +```sh +export PUPPET_VERSION="~> 5.5.6" +``` You can install all needed gems for spec tests into the modules directory by running: @@ -65,13 +72,17 @@ The test suite will run [Puppet Lint](http://puppet-lint.com/) and [Puppet Syntax](https://github.com/gds-operations/puppet-syntax) to check various syntax and style things. You can run these locally with: - bundle exec rake lint - bundle exec rake validate +```sh +bundle exec rake lint +bundle exec rake validate +``` It will also run some [Rubocop](http://batsov.com/rubocop/) tests against it. You can run those locally ahead of time with: - bundle exec rake rubocop +```sh +bundle exec rake rubocop +``` ## Running the unit tests @@ -82,15 +93,21 @@ about how best to test your new feature. To run the linter, the syntax checker and the unit tests: - bundle exec rake test +```sh +bundle exec rake test +``` To run your all the unit tests - bundle exec rake spec SPEC_OPTS='--format documentation' +```sh +bundle exec rake spec +``` To run a specific spec test set the `SPEC` variable: - bundle exec rake spec SPEC=spec/foo_spec.rb +```sh +bundle exec rake spec SPEC=spec/foo_spec.rb +``` ## Integration tests @@ -102,23 +119,51 @@ This fires up a new virtual machine (using vagrant) and runs a series of simple tests against it after applying the module. You can run this with: - bundle exec rake acceptance +```sh +bundle exec rake acceptance +``` This will run the tests on the module's default nodeset. You can override the nodeset used, e.g., - BEAKER_set=centos-7-x64 bundle exec rake acceptance +```sh +BEAKER_set=centos-7-x64 bundle exec rake acceptance +``` There are default rake tasks for the various acceptance test modules, e.g., - bundle exec rake beaker:centos-7-x64 - bundle exec rake beaker:ssh:centos-7-x64 +```sh +bundle exec rake beaker:centos-7-x64 +bundle exec rake beaker:ssh:centos-7-x64 +``` If you don't want to have to recreate the virtual machine every time you can use `BEAKER_destroy=no` and `BEAKER_provision=no`. On the first run you will at least need `BEAKER_provision` set to yes (the default). The Vagrantfile for the created virtual machines will be in `.vagrant/beaker_vagrant_files`. +Beaker also supports docker containers. We also use that in our automated CI +pipeline at [travis-ci](http://travis-ci.org). To use that instead of Vagrant: + +``` +PUPPET_INSTALL_TYPE=agent BEAKER_IS_PE=no BEAKER_PUPPET_COLLECTION=puppet5 BEAKER_debug=true BEAKER_setfile=debian9-64{hypervisor=docker} BEAKER_destroy=yes bundle exec rake beaker +``` + +You can replace the string `debian9` with any common operating system. +The following strings are known to work: + +* ubuntu1604 +* ubuntu1804 +* debian8 +* debian9 +* centos6 +* centos7 + The easiest way to debug in a docker container is to open a shell: - docker exec -it -u root ${container_id_or_name} bash +```sh +docker exec -it -u root ${container_id_or_name} bash +``` + +The source of this file is in our [modulesync_config](https://github.com/voxpupuli/modulesync_config/blob/master/moduleroot/.github/CONTRIBUTING.md.erb) +repository. diff --git a/.gitignore b/.gitignore index ac4a3f85..e9b3cf4b 100644 --- a/.gitignore +++ b/.gitignore @@ -18,4 +18,3 @@ Puppetfile.lock .*.sw? .yardoc/ Guardfile -Dockerfile.override diff --git a/.msync.yml b/.msync.yml index e1cef550..e1f48cab 100644 --- a/.msync.yml +++ b/.msync.yml @@ -1 +1 @@ -modulesync_config_version: '2.0.0' +modulesync_config_version: '2.1.0' diff --git a/.travis.yml b/.travis.yml index df09c920..2d50f36a 100644 --- a/.travis.yml +++ b/.travis.yml @@ -18,11 +18,11 @@ matrix: env: PUPPET_VERSION="~> 5.0" CHECK=test - rvm: 2.5.1 bundler_args: --without system_tests development release - env: PUPPET_VERSION="~> 5.0" CHECK=test_with_coveralls - - rvm: 2.4.4 - bundler_args: --without system_tests development release - env: PUPPET_VERSION="~> 5.0" CHECK=rubocop + env: PUPPET_VERSION="~> 6.0" CHECK=test_with_coveralls - rvm: 2.5.1 + bundler_args: --without system_tests development release + env: PUPPET_VERSION="~> 6.0" CHECK=rubocop + - rvm: 2.4.4 bundler_args: --without system_tests development release env: PUPPET_VERSION="~> 5.0" CHECK=build DEPLOY_TO_FORGE=yes branches: diff --git a/Gemfile b/Gemfile index 20f3df02..dd1b03a6 100644 --- a/Gemfile +++ b/Gemfile @@ -11,8 +11,7 @@ def location_for(place, fake_version = nil) end group :test do - gem 'puppetlabs_spec_helper', '~> 2.6', :require => false - gem 'rspec-puppet', '~> 2.5', :require => false + gem 'puppetlabs_spec_helper', '>= 2.11.0', :require => false gem 'rspec-puppet-facts', :require => false gem 'rspec-puppet-utils', :require => false gem 'puppet-lint-leading_zero-check', :require => false From 658c48ff04782b6ebe922cbd00d6cebf05dbdecc Mon Sep 17 00:00:00 2001 From: Tim Meusel Date: Sat, 13 Oct 2018 11:58:26 +0200 Subject: [PATCH 2/5] purge obsolete symlink setting in fixtures --- .fixtures.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.fixtures.yml b/.fixtures.yml index 9a86c35a..65a91c92 100644 --- a/.fixtures.yml +++ b/.fixtures.yml @@ -12,5 +12,3 @@ fixtures: epel: repo: "https://github.com/stahnma/puppet-module-epel" ref: "1.2.2" - symlinks: - gitlab: "#{source_dir}" From 615380e07e3f11d813e91ea011ab8d8ffa60613e Mon Sep 17 00:00:00 2001 From: Tim Meusel Date: Sat, 13 Oct 2018 11:58:58 +0200 Subject: [PATCH 3/5] test against master branch of each dependency --- .fixtures.yml | 16 ++++------------ 1 file changed, 4 insertions(+), 12 deletions(-) diff --git a/.fixtures.yml b/.fixtures.yml index 65a91c92..93613151 100644 --- a/.fixtures.yml +++ b/.fixtures.yml @@ -1,14 +1,6 @@ fixtures: repositories: - stdlib: - repo: "https://github.com/puppetlabs/puppetlabs-stdlib.git" - ref: "4.14.0" - apt: - repo: "https://github.com/puppetlabs/puppetlabs-apt.git" - ref: "2.2.0" - docker: - repo: "https://github.com/garethr/garethr-docker.git" - ref: "v4.1.1" - epel: - repo: "https://github.com/stahnma/puppet-module-epel" - ref: "1.2.2" + stdlib: "https://github.com/puppetlabs/puppetlabs-stdlib.git" + apt: "https://github.com/puppetlabs/puppetlabs-apt.git" + docker: "https://github.com/garethr/garethr-docker.git" + epel: "https://github.com/stahnma/puppet-module-epel" From 2cd36391f7e5b56cf69246ce6a112097b1f1221d Mon Sep 17 00:00:00 2001 From: Tim Meusel Date: Sat, 13 Oct 2018 12:03:06 +0200 Subject: [PATCH 4/5] allow puppet 6.x --- metadata.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/metadata.json b/metadata.json index abd51f34..d8170eec 100644 --- a/metadata.json +++ b/metadata.json @@ -67,7 +67,7 @@ "requirements": [ { "name": "puppet", - "version_requirement": ">= 4.10.0 < 6.0.0" + "version_requirement": ">= 4.10.0 < 7.0.0" } ] } From adf6ad66ed46ce3c832cb844d0fab9a9ddfc6ba9 Mon Sep 17 00:00:00 2001 From: Tim Meusel Date: Sat, 13 Oct 2018 12:14:29 +0200 Subject: [PATCH 5/5] add yumrepo_core module to fixtures --- .fixtures.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.fixtures.yml b/.fixtures.yml index 93613151..a3d00ce4 100644 --- a/.fixtures.yml +++ b/.fixtures.yml @@ -4,3 +4,6 @@ fixtures: apt: "https://github.com/puppetlabs/puppetlabs-apt.git" docker: "https://github.com/garethr/garethr-docker.git" epel: "https://github.com/stahnma/puppet-module-epel" + yumrepo_core: + repo: https://github.com/puppetlabs/puppetlabs-yumrepo_core.git + puppet_version: ">= 6.0.0"