08e765fc3d
Start off the removal of the docker directory by making the gate only run against docker templates. The idea is we are going to from this patch set forward completely abandon the functioning of the docker directory and focus on making templates work properly. In order to facilitate that, this patch set makes sure each change gates properly for the changed service in the Templates build. Note because git review and gerrit can't keep history on removal followed by a git move operation, we first git rm the files affected then git mv them to get the gate working again. Every other patch in this patch set will fail the gate. That is expected behavior. Change-Id: I1be2e2638aef4ada038bfe5f3dd563f040542df2
102 lines
3.6 KiB
Python
102 lines
3.6 KiB
Python
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
|
|
from mock import patch
|
|
from os import path
|
|
from oslo_log import fixture as log_fixture
|
|
from oslo_log import log as logging
|
|
from oslotest import base
|
|
|
|
import sys
|
|
sys.path.append(path.abspath(path.join(path.dirname(__file__), '../tools')))
|
|
from kolla.cmd import build
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class BuildTest(base.BaseTestCase):
|
|
|
|
def setUp(self):
|
|
super(BuildTest, self).setUp()
|
|
self.useFixture(log_fixture.SetLogLevel([__name__],
|
|
logging.logging.INFO))
|
|
self.build_args = [__name__, "--debug"]
|
|
|
|
def runTest(self):
|
|
with patch.object(sys, 'argv', self.build_args):
|
|
LOG.info("Running with args %s" % self.build_args)
|
|
bad_results, good_results, unmatched_results = build.main()
|
|
|
|
# these are images that are known to not build properly
|
|
excluded_images = ["gnocchi-base",
|
|
"murano-base"]
|
|
|
|
failures = 0
|
|
for image, result in bad_results.iteritems():
|
|
if image in excluded_images:
|
|
if result is 'error':
|
|
continue
|
|
failures = failures + 1
|
|
LOG.warning(">>> Expected image '%s' to fail, please update"
|
|
" the excluded_images in source file above if the"
|
|
" image build has been fixed." % image)
|
|
else:
|
|
if result is not 'error':
|
|
continue
|
|
failures = failures + 1
|
|
LOG.critical(">>> Expected image '%s' to succeed!" % image)
|
|
|
|
for image in unmatched_results.keys():
|
|
failures = failures + 1
|
|
LOG.critical(">>> Expected image '%s' to be matched!" % image)
|
|
|
|
self.assertEqual(failures, 0, "%d failure(s) occurred" % failures)
|
|
|
|
|
|
class BuildTestCentosBinaryDocker(BuildTest):
|
|
def setUp(self):
|
|
super(BuildTestCentosBinaryDocker, self).setUp()
|
|
self.build_args.extend(["--base", "centos",
|
|
"--type", "binary"])
|
|
|
|
|
|
class BuildTestCentosSourceDocker(BuildTest):
|
|
def setUp(self):
|
|
super(BuildTestCentosSourceDocker, self).setUp()
|
|
self.build_args.extend(["--base", "centos",
|
|
"--type", "source"])
|
|
|
|
|
|
class BuildTestCentosBinaryTemplate(BuildTest):
|
|
def setUp(self):
|
|
super(BuildTestCentosBinaryTemplate, self).setUp()
|
|
self.build_args.extend(["--base", "centos",
|
|
"--type", "binary",
|
|
"--template"])
|
|
|
|
|
|
class BuildTestCentosSourceTemplate(BuildTest):
|
|
def setUp(self):
|
|
super(BuildTestCentosSourceTemplate, self).setUp()
|
|
self.build_args.extend(["--base", "centos",
|
|
"--type", "source",
|
|
"--template"])
|
|
|
|
|
|
class BuildTestUbuntuSourceTemplate(BuildTest):
|
|
def setUp(self):
|
|
super(BuildTestUbuntuSourceTemplate, self).setUp()
|
|
self.build_args.extend(["--base", "ubuntu",
|
|
"--type", "source",
|
|
"--template"])
|