tests: Make it easier to update version globs

Use constants so we won't have to edit a dozen places in the test when
the package versions are bumped.

Related: rhbz#1678937
This commit is contained in:
Brian C. Lane 2019-03-08 10:09:42 -08:00
parent a2252112d4
commit 6242ae8b18
4 changed files with 73 additions and 59 deletions

View File

@ -4,7 +4,7 @@ version = "0.0.1"
[[packages]] [[packages]]
name = "tmux" name = "tmux"
version = "2.8" version = "*"
[[packages]] [[packages]]
name = "openssh-server" name = "openssh-server"

View File

@ -3,11 +3,11 @@ description = "An example GlusterFS server with samba"
[[modules]] [[modules]]
name = "glusterfs" name = "glusterfs"
version = "4.0.*" version = "*"
[[modules]] [[modules]]
name = "glusterfs-fuse" name = "glusterfs-fuse"
version = "4.0.*" version = "*"
[[packages]] [[packages]]
name = "samba" name = "samba"

View File

@ -12,11 +12,11 @@ version = "2.4.*"
[[modules]] [[modules]]
name = "php" name = "php"
version = "7.2.*" version = "7.*"
[[modules]] [[modules]]
name = "php-mysqlnd" name = "php-mysqlnd"
version = "7.2.*" version = "7.*"
[[packages]] [[packages]]
name = "tmux" name = "tmux"

View File

@ -28,6 +28,7 @@ import unittest
from flask import json from flask import json
import pytoml as toml import pytoml as toml
from pylorax.api.config import configure, make_dnf_dirs, make_queue_dirs from pylorax.api.config import configure, make_dnf_dirs, make_queue_dirs
from pylorax.api.errors import * # pylint: disable=wildcard-import from pylorax.api.errors import * # pylint: disable=wildcard-import
from pylorax.api.queue import start_queue_monitor from pylorax.api.queue import start_queue_monitor
@ -39,6 +40,19 @@ from pylorax.sysutils import joinpaths
# Used for testing UTF-8 input support # Used for testing UTF-8 input support
UTF8_TEST_STRING = "I 𝒊ll 𝟉ο𝘁 𝛠𝔰 𝘁𝒉𝝸𝚜" UTF8_TEST_STRING = "I 𝒊ll 𝟉ο𝘁 𝛠𝔰 𝘁𝒉𝝸𝚜"
# HELPER CONSTANTS.
HTTP_GLOB = {"name":"httpd", "version":"2.4.*"}
MODSSL_GLOB = {"name":"mod_ssl", "version":"2.4.*"}
PHP_GLOB = {"name":"php", "version":"7.*"}
PHPMYSQL_GLOB = {"name": "php-mysqlnd", "version":"7.*"}
OPENSSH_GLOB = {"name":"openssh-server", "version": "7.*"}
RSYNC_GLOB = {"name": "rsync", "version": "3.1.*"}
SAMBA_GLOB = {"name": "samba", "version": "4.*.*"}
TMUX_GLOB = {"name": "tmux", "version": "*"}
GLUSTERFS_GLOB = {"name": "glusterfs", "version": "*"}
GLUSTERFSFUSE_GLOB = {"name": "glusterfs-fuse", "version": "*"}
def get_system_repo(): def get_system_repo():
"""Get an enabled system repo from /etc/yum.repos.d/*repo """Get an enabled system repo from /etc/yum.repos.d/*repo
@ -153,14 +167,14 @@ class ServerTestCase(unittest.TestCase):
info_dict_1 = {"changes":[{"changed":False, "name":"example-http-server"}], info_dict_1 = {"changes":[{"changed":False, "name":"example-http-server"}],
"errors":[], "errors":[],
"blueprints":[{"description":"An example http server with PHP and MySQL support.", "blueprints":[{"description":"An example http server with PHP and MySQL support.",
"modules":[{"name":"httpd", "version":"2.4.*"}, "modules":[HTTP_GLOB,
{"name":"mod_ssl", "version":"2.4.*"}, MODSSL_GLOB,
{"name":"php", "version":"7.2.*"}, PHP_GLOB,
{"name": "php-mysqlnd", "version":"7.2.*"}], PHPMYSQL_GLOB],
"name":"example-http-server", "name":"example-http-server",
"packages": [{"name":"openssh-server", "version": "7.*"}, "packages": [OPENSSH_GLOB,
{"name": "rsync", "version": "3.1.*"}, RSYNC_GLOB,
{"name": "tmux", "version": "*"}], TMUX_GLOB],
"groups": [], "groups": [],
"version": "0.0.1"}]} "version": "0.0.1"}]}
resp = self.server.get("/api/v0/blueprints/info/example-http-server") resp = self.server.get("/api/v0/blueprints/info/example-http-server")
@ -173,21 +187,21 @@ class ServerTestCase(unittest.TestCase):
{"changed":False, "name":"example-http-server"}], {"changed":False, "name":"example-http-server"}],
"errors":[], "errors":[],
"blueprints":[{"description": "An example GlusterFS server with samba", "blueprints":[{"description": "An example GlusterFS server with samba",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-fuse", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"name":"example-glusterfs", "name":"example-glusterfs",
"packages":[{"name":"samba", "version":"4.*.*"}], "packages":[SAMBA_GLOB],
"groups": [], "groups": [],
"version": "0.0.1"}, "version": "0.0.1"},
{"description":"An example http server with PHP and MySQL support.", {"description":"An example http server with PHP and MySQL support.",
"modules":[{"name":"httpd", "version":"2.4.*"}, "modules":[HTTP_GLOB,
{"name":"mod_ssl", "version":"2.4.*"}, MODSSL_GLOB,
{"name":"php", "version":"7.2.*"}, PHP_GLOB,
{"name": "php-mysqlnd", "version":"7.2.*"}], PHPMYSQL_GLOB],
"name":"example-http-server", "name":"example-http-server",
"packages": [{"name":"openssh-server", "version": "7.*"}, "packages": [OPENSSH_GLOB,
{"name": "rsync", "version": "3.1.*"}, RSYNC_GLOB,
{"name": "tmux", "version": "*"}], TMUX_GLOB],
"groups": [], "groups": [],
"version": "0.0.1"}, "version": "0.0.1"},
]} ]}
@ -236,10 +250,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba", test_blueprint = {"description": "An example GlusterFS server with samba",
"name":"example-glusterfs", "name":"example-glusterfs",
"version": "0.2.0", "version": "0.2.0",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-fuse", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"2.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/new", resp = self.server.post("/api/v0/blueprints/new",
@ -287,10 +301,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba, ws version", test_blueprint = {"description": "An example GlusterFS server with samba, ws version",
"name":"example-glusterfs", "name":"example-glusterfs",
"version": "0.3.0", "version": "0.3.0",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-fuse", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"2.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/workspace", resp = self.server.post("/api/v0/blueprints/workspace",
@ -314,10 +328,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba, ws version", test_blueprint = {"description": "An example GlusterFS server with samba, ws version",
"name":"example-glusterfs", "name":"example-glusterfs",
"version": "0.4.0", "version": "0.4.0",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-fuse", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"2.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/workspace", resp = self.server.post("/api/v0/blueprints/workspace",
@ -364,10 +378,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba, ws version", test_blueprint = {"description": "An example GlusterFS server with samba, ws version",
"name":"example-glusterfs", "name":"example-glusterfs",
"version": "1.4.0", "version": "1.4.0",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-cli", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"2.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/workspace", resp = self.server.post("/api/v0/blueprints/workspace",
data=json.dumps(test_blueprint), data=json.dumps(test_blueprint),
@ -483,10 +497,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba, ws version", test_blueprint = {"description": "An example GlusterFS server with samba, ws version",
"name":"example-glusterfs", "name":"example-glusterfs",
"version": "0.3.0", "version": "0.3.0",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-fuse", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"2.8"}]} TMUX_GLOB]}
resp = self.server.post("/api/v0/blueprints/workspace", resp = self.server.post("/api/v0/blueprints/workspace",
data=json.dumps(test_blueprint), data=json.dumps(test_blueprint),
@ -502,7 +516,7 @@ class ServerTestCase(unittest.TestCase):
"old": {"Description": "An example GlusterFS server with samba"}}, "old": {"Description": "An example GlusterFS server with samba"}},
{"new": {"Version": "0.3.0"}, {"new": {"Version": "0.3.0"},
"old": {"Version": "0.0.1"}}, "old": {"Version": "0.0.1"}},
{"new": {"Package": {"version": "2.8", "name": "tmux"}}, {"new": {"Package": TMUX_GLOB},
"old": None}]} "old": None}]}
self.assertEqual(data, result) self.assertEqual(data, result)
@ -760,10 +774,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba", test_blueprint = {"description": "An example GlusterFS server with samba",
"name":"example-glusterfs", "name":"example-glusterfs",
"version": "0.2.0", "version": "0.2.0",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-fuse", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"2.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/new?branch=test", resp = self.server.post("/api/v0/blueprints/new?branch=test",
@ -1283,10 +1297,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba", test_blueprint = {"description": "An example GlusterFS server with samba",
"name":UTF8_TEST_STRING, "name":UTF8_TEST_STRING,
"version": "0.2.0", "version": "0.2.0",
"modules":[{"name":"glusterfs", "version":"3.*.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-cli", "version":"3.*.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"1.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/new", resp = self.server.post("/api/v0/blueprints/new",
@ -1313,10 +1327,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "An example GlusterFS server with samba, ws version", test_blueprint = {"description": "An example GlusterFS server with samba, ws version",
"name":UTF8_TEST_STRING, "name":UTF8_TEST_STRING,
"version": "0.3.0", "version": "0.3.0",
"modules":[{"name":"glusterfs", "version":"3.*.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-cli", "version":"3.*.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"1.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/workspace", resp = self.server.post("/api/v0/blueprints/workspace",
@ -1465,10 +1479,10 @@ class ServerTestCase(unittest.TestCase):
test_blueprint = {"description": "A blueprint that has been deleted", test_blueprint = {"description": "A blueprint that has been deleted",
"name":"deleted-blueprint", "name":"deleted-blueprint",
"version": "0.0.1", "version": "0.0.1",
"modules":[{"name":"glusterfs", "version":"4.0.*"}, "modules":[GLUSTERFS_GLOB,
{"name":"glusterfs-cli", "version":"4.0.*"}], GLUSTERFSFUSE_GLOB],
"packages":[{"name":"samba", "version":"4.*.*"}, "packages":[SAMBA_GLOB,
{"name":"tmux", "version":"2.8"}], TMUX_GLOB],
"groups": []} "groups": []}
resp = self.server.post("/api/v0/blueprints/new", resp = self.server.post("/api/v0/blueprints/new",