Commit Graph

35 Commits

Author SHA1 Message Date
K Jonathan Harker
74a92c4645 Fix logstash-filters test
In order to run the script directly in the test, the script needs to
have the executable bit set. Currently, the test is failing with a
"Permission denied" error when attempting to run the script.

We also need to run install_modules.sh in the logstash-filters test, so
move that invocation to the shared prep-apply.sh script.

The vcsrepo puppet define doesn't understand revisions of the form
"refs/zuul/foo", so instead parse the HEAD sha and pass that to vcsrepo.

Finally, we need to ensure that $elasticsearch_nodes is populated with
an array, otherwise the function @elasticsearch_nodes.map in the
output.conf template will fail.

Change-Id: Ic1ab6d04232abb3cf347f0d27afbf9172f62b0e4
2016-10-12 09:43:26 -07:00
Clark Boylan
8b642ecacc Run a primer puppet run before parallel puppet
We are seeing races in the puppet apply test to create
/opt/system-config/hieradata. Avoid this by running a simple hello world
puppet manifest prior to running all of our test manifests in parallel.
This should force the ansible puppet role to populate all the things on
disk first avoiding races.

Change-Id: If3946f561535ba315f018ab3122dcde56144240f
2016-10-07 11:12:00 -07:00
James E. Blair
e82731f0f3 Run ansible apply test in parallel
Change-Id: Ic5b5ef5ca115ca244ebf86079f9b192fbb13fad6
2016-10-04 15:29:25 -07:00
James E. Blair
a01bec1fc6 Use ansible for puppet apply test
This is needed since the hiera configuration is in the ansible
role.

Have puppet append its output directly to our per-test output file.

Rename that file with a FAILED suffix for easy identification when
looking at the results in the published log directory.

Change-Id: Ie2a028b9e0179168d279bcf33de7f997cdfdbc8d
Depends-On: I0db01d128258f78e9b196354799a80774f6c6808
2016-10-04 22:29:00 +00:00
K Jonathan Harker
166b00c17f Add support for logstash-filter integration tests
Add a script for integration testing with
openstack-infra/logstash-filters and refactor the apply-test script to
leverage much of the prep work done there.

Also add some needed parameters to install arbitrary versions of the
logstash-filters repo.

Change-Id: Ifcc7fb13c4fb21986e33327487c739966e4bb107
2016-05-25 14:06:15 -07:00
Paul Belanger
ae2b68c4b7 Run puppet-apply on debian jessie jenkins slaves
Change-Id: I4e876f997324bdb43732bec26067d88531b587d5
Signed-off-by: Paul Belanger <pabelanger@redhat.com>
2016-03-16 20:15:18 -04:00
Spencer Krum
691897db6f Use In-Tree Public Hiera data
Also make the apply-test public-hiera aware

Change-Id: I761bf49ed6279a492cabeca878ec5e7c0fac3d0e
2015-12-30 13:31:17 -08:00
Clark Boylan
ff17732828 Remove centos6 support
This removes centos6 support from install_puppet.sh because centos6 is
no longer supported so this code is dead.

Change-Id: If59f10a6a9c576b1299b0e49a2e82d2a1a1d7ecf
2015-12-04 13:05:10 -08:00
Spencer Krum
8cdaf92609 Treat openstack_health normally
This is a partial revert of 05c16e2e that removes special casing around
the openstack-health/openstack_health repo.

Change-Id: I832f1b764a34c128d737a467fa568cc064226c5a
2015-11-06 10:00:14 -08:00
Jenkins
36ac4f52ed Merge "Make hiera default values optional" 2015-10-23 22:35:56 +00:00
Matthew Treinish
05c16e2e35
Add openstack-health api server
This commit adds the puppet config for running an openstack-health
api instance. It'll use the subunit2sql trove db node as a data
source. The puppet-openstack-health module is incorrectly named which
is causing issues, a workaround to rename the repo is added to
install_modules.sh. This is a temporary measure until the gerrit
rename is completed. There is also a workaround in the apply test.

Change-Id: I7e6d9664d087e7bdc21d92624991d0d5f86c0c99
2015-10-19 15:27:00 -04:00
K Jonathan Harker
cd00179976 Make hiera default values optional
Currently, all hiera calls need to have default values in order for the
apply test to work. This is done by using sed to replace the hiera call
with the default value in the call, i.e. 'hiera("foo", "bar")' is
replaced with '"bar"'.

This adds another sed command that replaces a hiera call that has no
default value specified with the name of the key appended with
NoDefault, i.e. 'hiera("foo")' will become '"fooNoDefault"'.

By making the hiera default values optional, we no longer need to pass
in a default value to every hiera call, and so we can remove the
placeholder XXX that were previously needed by the apply tests but not
by puppet itself.

Change-Id: Ibdeb0c2e49245ea05116e8043936d5b012f46666
2015-10-16 14:03:35 -07:00
Jenkins
5a7c74c6d4 Merge "Test that modules.env is complete" 2015-10-07 07:10:31 +00:00
Colleen Murphy
324e5c4f57 Make apply test more configurable
The Infra Cloud project uses a different set of puppet modules than the
standard infra ones in order to avoid possible dependency conflicts[1].
Currently the puppet-apply test hard-codes the entry-point puppet
manifest and module list. This patch makes the manifest, currently
manifests/site.pp, and the module file, currently modules.env,
configurable, so that we can add a new job to test just these nodes
with the correct modules installed.

[1] https://review.openstack.org/#/c/209617/

Change-Id: I744123befef0bf27a1eb2a79f5d814e0cefe81f5
2015-09-24 15:52:03 -07:00
K Jonathan Harker
a359cea46c Test that modules.env is complete
The test slaves that the apply tests run on have puppet modules
installed from the initial slave configuration. Delete the previously
installed modules before re-installing to ensure that the apply test
only uses the modules listed in the current change's modules.env.

Change-Id: Ie62b64133c480c05968ab554185527ac5e432858
2015-08-19 15:43:31 -07:00
Jenkins
065fde589b Merge "Don't clone project-config for puppet-apply jobs" 2015-08-05 19:26:06 +00:00
Paul Belanger
037351ee19 Add fedora support for apply-test.sh
Change-Id: Id9d6e2977ff13c58f7fc6a31957a250bbe728c2e
Depends-On: Ia1a72f7b7e58a4e9861c6d5916521d0c0ad7f8ec
Signed-off-by: Paul Belanger <pabelanger@redhat.com>
2015-08-05 11:25:53 -04:00
Paul Belanger
55f6e468a1 Add centos7 support for apply-test.sh
Change-Id: I10da00d7e4e8dcbad5c095cbeee2bc8f4c389bb6
Signed-off-by: Paul Belanger <pabelanger@redhat.com>
2015-08-04 16:09:13 -04:00
Ian Wienand
f660901160 Don't clone project-config for puppet-apply jobs
It does not appear these jobs actually require the project-config repo
for anything.  It was added in
I3a772e84a1bc6028caeabcc8e09a0942f44b8612 without a lot of
explaination of why, but as it stands I don't see the project-config
affects the outcome of these jobs?

Change-Id: I85111afbbce497c86f4f6d8dfe74944c32a77b80
2015-07-28 15:58:36 +10:00
Paul Belanger
be7adfa7f2 Display puppet apply results right after running
Otherwise, there is a case where the results are not rendered properly
because the shell exits.

Change-Id: Ica05615cad4fcc15c9d941d16f74cb4f68bc5a99
Signed-off-by: Paul Belanger <pabelanger@redhat.com>
2015-07-08 16:36:36 -04:00
Jenkins
1e3c065182 Merge "Print the node definition before apply test" 2015-07-03 00:50:56 +00:00
Spencer Krum
284749fb4d Print the node definition before apply test
This makes it easier to tell which node definition is being evaluated
Because xargs -P doesn't do bash functions, some of the apply_test has
been moved into test_puppet_apply.sh. All the test snippets and test
output is being recorded in files in tools/opt, then catted for the
user.

Change-Id: I4fb77f93f9e9a7216b62634438a11d8d297bdefe
2015-06-12 17:11:25 -07:00
Clark Boylan
797feda87a Allow blank lines in node{} with apply test
The apply test does some really simple string manipulation to generate
puppet manifests based on our site.pp on the fly. Unfortunately the old
code assumed there would be no blank lines within a node{} definition.
This assumption is breaking as we work to decouple the
openstack_project::server contents from within openstack_project
manifests and move that into site.pp.

This is a relatively simple fix where we csplit nodes based on the
previous /^}$/ which ends the last node{} definition instead of
splitting on blank lines. Added some comments to make what the parsing
does a bit more clear.

Change-Id: I2cc7317ed90423d6f923c4303a76e091a0bc2ebb
2015-04-23 11:34:10 -07:00
Jenkins
ca37048c3f Merge "Revert "Puppet apply test creates puppet directory env"" 2015-02-11 00:45:08 +00:00
Jenkins
cef96469f1 Merge "Making the apply test easier to read" 2015-01-25 14:13:06 +00:00
Jeremy Stanley
35f642b68a Revert "Puppet apply test creates puppet directory env"
This reverts commit 3b563fb59e.

Do not approve until Ief6c8e9bf7d71ddc63dba484390124546f14b93a is
applied to new nodepool images.

Change-Id: Ia7422d4f8fe316cc37c1310def0e7a9e2f232d35
2014-12-12 19:09:31 +00:00
Jeremy Stanley
3b563fb59e Puppet apply test creates puppet directory env
Make /etc/puppet/environments/production/environment.conf so that
the apply test will find a default directory environment.

Change-Id: I062949d6c23545c40690edc39302095b0dec3c84
2014-12-12 16:08:02 +00:00
Spencer Krum
ed46e9303f Source modules.env from apply-test.sh
This causes apply-test.sh to get the list of puppet modules to do
integration test with from modules.env. Modules.env has been
refactored to have three lists of modules: Package modules(MODULES),
SOURCE_MODULES, and INTEGRATION_MODULES.

When PUPPET_INTEGRATION_TEST is not set, INTEGRATION_MODULES is
folded into SOURCE_MODULES.

In apply-test.sh, INTEGRATION_MODULES is sourced from modules.env
and some string/array manipulation is performed to pass each entry
to zuul-cloner.

Change-Id: I47302c5c7e8c41b985f16a05c4e9b8078ea867a3
2014-11-18 21:23:43 +00:00
Spencer Krum
ca76e0c8dd Making the apply test easier to read
--color=false remove ansi escapes
cping /etc/hiera.yaml /etc/puppet/hiera.yaml shuts up puppet
complaining that it doesn't have  hiera.yaml to read

Change-Id: Iea7222c66f2fcc1338bc7baffb572d1a1ab2ecd6
2014-11-17 07:49:52 +00:00
Ramy Asselin
1bf253f91b Split out jenkins module
Part of an effort to split most of puppet modules out of system-config:
http://specs.openstack.org/openstack-infra/infra-specs/specs/puppet-modules.html

Depends-On: https://review.openstack.org/#/c/131302/

Change-Id: I1f6588c46a53d83249de68be6c2b36ddb3c805cb
2014-11-13 13:26:44 -08:00
Mikhail S Medvedev
f27dc5fcd1 Split out kibana module
Part of an effort to split most of puppet modules out of system-config.

https://review.openstack.org/#/c/130619/ should land before this
commit can be merged.

Change-Id: I7720ad7d2b25816c63e971112a7a733bde52b7f3
2014-10-27 14:39:32 -05:00
K Jonathan Harker
948aff1f02 Clean up bashate failures
Fix all of the bashate failures.  Also, bashate will install its negative
tests in its virtualenv, so we need to generate a list of files to pass to
bashate that excludes .tox/

Change-Id: I55559bf6137f705aec9a7f277928ad8d4cadc2ca
2014-09-30 12:40:59 -07:00
Monty Taylor
8387e739fe Add project-config to zuul cloner
Make sure that the puppet apply test gets the project-config repo.

Change-Id: I3a772e84a1bc6028caeabcc8e09a0942f44b8612
2014-09-25 15:58:51 -07:00
James E. Blair
542e170b81 Keep environment for cloner in apply test sudo
The zuul cloner needs the ZUUL_* env vars when setting up projects
for the new apply integration test.

Also, add some more debugging to both versions of the test.

Change-Id: I486b19cecd034250068e4a59604e1e0ca90ed83d
2014-09-15 13:19:37 -07:00
James E. Blair
9d23185ac5 Add integration apply test
Make module installation conditional in install_modules.sh so that
we can specify that we _do not_ want it to install the modules
that will be participating in the integration test.

Add a variant of the apply test script (currently test.sh) that
uses zuul-cloner to check out the appropriate versions of modules
that are participating in the integration test.

Add jobs that run this to the experimental pipeline.

Change-Id: I16055cdd45f6e05aa8ebceb500c5709f265268df
2014-09-03 15:03:09 -07:00