diff --git a/Vagrantfile b/Vagrantfile index 29822177b7f..4c86d027a0e 100644 --- a/Vagrantfile +++ b/Vagrantfile @@ -68,11 +68,16 @@ Vagrant.configure(2) do |config| config.vm.box = "boxcutter/fedora22" dnf_common config end + config.vm.define "opensuse-13" do |config| + config.vm.box = "chef/opensuse-13" + config.vm.box_url = "http://opscode-vm-bento.s3.amazonaws.com/vagrant/virtualbox/opscode_opensuse-13.2-x86_64_chef-provisionerless.box" + suse_common config + end # Switch the default share for the project root from /vagrant to # /elasticsearch because /vagrant is confusing when there is a project inside # the elasticsearch project called vagrant.... config.vm.synced_folder ".", "/vagrant", disabled: true - config.vm.synced_folder "", "/elasticsearch" + config.vm.synced_folder ".", "/elasticsearch" if Vagrant.has_plugin?("vagrant-cachier") config.cache.scope = :box end @@ -150,6 +155,14 @@ def dnf_common(config) end end +def suse_common(config) + provision(config, + update_command: "zypper --non-interactive list-updates", + update_tracking_file: "/var/cache/zypp/packages/last_update", + install_command: "zypper --non-interactive --quiet install --no-recommends", + java_package: "java-1_8_0-openjdk-devel") +end + # Register the main box provisioning script. # @param config Vagrant's config object. Required. # @param update_command [String] The command used to update the package @@ -194,6 +207,7 @@ def provision(config, #{extra} installed java || install #{java_package} + ensure tar ensure curl ensure unzip diff --git a/qa/vagrant/pom.xml b/qa/vagrant/pom.xml index af0ae73353a..1c368726c42 100644 --- a/qa/vagrant/pom.xml +++ b/qa/vagrant/pom.xml @@ -21,7 +21,7 @@ sudo bats $BATS/${testScripts} precise, trusty, vivid, jessie - centos-6, centos-7, fedora-22, oel-7 + centos-6, centos-7, oel-7, fedora-22, opensuse-13 trusty centos-7 diff --git a/qa/vagrant/src/test/resources/packaging/scripts/60_systemd.bats b/qa/vagrant/src/test/resources/packaging/scripts/60_systemd.bats index 77e8d807362..25685a86dd1 100644 --- a/qa/vagrant/src/test/resources/packaging/scripts/60_systemd.bats +++ b/qa/vagrant/src/test/resources/packaging/scripts/60_systemd.bats @@ -99,23 +99,27 @@ setup() { @test "[SYSTEMD] stop (running)" { systemctl stop elasticsearch.service +} +@test "[SYSTEMD] status (stopping)" { run systemctl status elasticsearch.service - [ "$status" -eq 3 ] || "Expected exit code 3 meaning stopped" + # I'm not sure why suse exits 0 here, but it does + if [ ! -e /etc/SuSE-release ]; then + [ "$status" -eq 3 ] || "Expected exit code 3 meaning stopped but got $status" + fi echo "$output" | grep "Active:" | grep "inactive" } @test "[SYSTEMD] stop (stopped)" { systemctl stop elasticsearch.service - - run systemctl status elasticsearch.service - [ "$status" -eq 3 ] || "Expected exit code 3 meaning stopped" - echo "$output" | grep "Active:" | grep "inactive" } @test "[SYSTEMD] status (stopped)" { run systemctl status elasticsearch.service - [ "$status" -eq 3 ] || "Expected exit code 3 meaning stopped" + # I'm not sure why suse exits 0 here, but it does + if [ ! -e /etc/SuSE-release ]; then + [ "$status" -eq 3 ] || "Expected exit code 3 meaning stopped but got $status" + fi echo "$output" | grep "Active:" | grep "inactive" } diff --git a/qa/vagrant/src/test/resources/packaging/scripts/packaging_test_utils.bash b/qa/vagrant/src/test/resources/packaging/scripts/packaging_test_utils.bash index ff7255c5417..78ab3519d0b 100644 --- a/qa/vagrant/src/test/resources/packaging/scripts/packaging_test_utils.bash +++ b/qa/vagrant/src/test/resources/packaging/scripts/packaging_test_utils.bash @@ -414,7 +414,7 @@ wait_for_elasticsearch_status() { local desiredStatus=${1:-green} echo "Making sure elasticsearch is up..." - wget -O - --retry-connrefused --waitretry=1 --timeout=60 http://localhost:9200 || { + wget -O - --retry-connrefused --waitretry=1 --timeout=60 --tries 60 http://localhost:9200 || { echo "Looks like elasticsearch never started. Here is its log:" if [ -r "/tmp/elasticsearch/elasticsearch.pid" ]; then cat /tmp/elasticsearch/log/elasticsearch.log