Add More Freezer Tempest Tests
Continue to develop integration tests that get run with Tempest tests. Continue to get more test coverage. Change-Id: I4ad40d84305eca0204ecdb72ee559f95837b1218
This commit is contained in:
parent
c1a974a26d
commit
9f8ec0b9b9
|
@ -44,7 +44,7 @@ symbols=no
|
||||||
# --enable=similarities". If you want to run only the classes checker, but have
|
# --enable=similarities". If you want to run only the classes checker, but have
|
||||||
# no Warning level messages displayed, use"--disable=all --enable=classes
|
# no Warning level messages displayed, use"--disable=all --enable=classes
|
||||||
# --disable=W"
|
# --disable=W"
|
||||||
disable=W,C,R
|
disable=W,C,R,E1002
|
||||||
|
|
||||||
|
|
||||||
[REPORTS]
|
[REPORTS]
|
||||||
|
|
|
@ -11,8 +11,43 @@
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
import os
|
||||||
|
|
||||||
import tempest.test
|
import tempest.test
|
||||||
|
|
||||||
class BaseFreezerTest(tempest.test.BaseTestCase):
|
class BaseFreezerTest(tempest.test.BaseTestCase):
|
||||||
pass
|
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
|
||||||
|
super(BaseFreezerTest, self).__init__(*args, **kwargs)
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
|
||||||
|
super(BaseFreezerTest, self).setUp()
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
|
||||||
|
super(BaseFreezerTest, self).tearDown()
|
||||||
|
|
||||||
|
def get_environ(self):
|
||||||
|
|
||||||
|
os.environ['OS_REGION_NAME'] = 'RegionOne'
|
||||||
|
os.environ['OS_PASSWORD'] = 'secretadmin'
|
||||||
|
os.environ['OS_IDENTITY_API_VERSION'] = '2.0'
|
||||||
|
os.environ['OS_NO_CACHE'] = '1'
|
||||||
|
os.environ['OS_USERNAME'] = 'demo'
|
||||||
|
os.environ['OS_VOLUME_API_VERSION'] = '2'
|
||||||
|
os.environ['OS_PROJECT_NAME'] = 'demo'
|
||||||
|
os.environ['PYTHONUNBUFFERED'] = '1'
|
||||||
|
os.environ['OS_TENANT_NAME'] = 'demo'
|
||||||
|
os.environ['OS_TENANT_ID'] = ''
|
||||||
|
|
||||||
|
# Allow developers to set OS_AUTH_URL when developing so that
|
||||||
|
# Keystone may be on a host other than localhost.
|
||||||
|
if not 'OS_AUTH_URL' in os.environ:
|
||||||
|
os.environ['OS_AUTH_URL'] = 'http://localhost:5000/v2.0'
|
||||||
|
|
||||||
|
# Mac OS X uses gtar located in /usr/local/bin
|
||||||
|
os.environ['PATH'] = '/usr/local/bin:' + os.environ['PATH']
|
||||||
|
|
||||||
|
return os.environ
|
|
@ -0,0 +1,122 @@
|
||||||
|
# (C) Copyright 2016 Hewlett Packard Enterprise Development Company LP
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
import os
|
||||||
|
import shutil
|
||||||
|
|
||||||
|
import datetime
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
from freezer.tests.freezer_tempest_plugin.tests.api import base
|
||||||
|
from tempest import test
|
||||||
|
|
||||||
|
|
||||||
|
class TestFreezerFSBackup(base.BaseFreezerTest):
|
||||||
|
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
|
||||||
|
super(TestFreezerFSBackup, self).__init__(*args, **kwargs)
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
|
||||||
|
super(TestFreezerFSBackup, self).setUp()
|
||||||
|
|
||||||
|
now_in_secs = datetime.datetime.now().strftime("%s")
|
||||||
|
|
||||||
|
self.backup_source_dir = ("/tmp/freezer-test-backup-source/"
|
||||||
|
+ now_in_secs)
|
||||||
|
|
||||||
|
self.backup_source_sub_dir = self.backup_source_dir + "/subdir"
|
||||||
|
|
||||||
|
self.restore_target_dir = (
|
||||||
|
"/tmp/freezer-test-backup-restore/"
|
||||||
|
+ now_in_secs)
|
||||||
|
|
||||||
|
self.backup_local_storage_dir = (
|
||||||
|
"/tmp/freezer-test-backup-local-storage/"
|
||||||
|
+ now_in_secs)
|
||||||
|
|
||||||
|
self.freezer_backup_name = 'freezer-test-backup-fs-0'
|
||||||
|
|
||||||
|
shutil.rmtree(self.backup_source_dir, True)
|
||||||
|
os.makedirs(self.backup_source_dir)
|
||||||
|
open(self.backup_source_dir + "/a", 'w').close()
|
||||||
|
open(self.backup_source_dir + "/b", 'w').close()
|
||||||
|
open(self.backup_source_dir + "/c", 'w').close()
|
||||||
|
|
||||||
|
os.makedirs(self.backup_source_sub_dir)
|
||||||
|
open(self.backup_source_sub_dir + "/x", 'w').close()
|
||||||
|
open(self.backup_source_sub_dir + "/y", 'w').close()
|
||||||
|
open(self.backup_source_sub_dir + "/z", 'w').close()
|
||||||
|
|
||||||
|
shutil.rmtree(self.restore_target_dir, True)
|
||||||
|
os.makedirs(self.restore_target_dir)
|
||||||
|
|
||||||
|
shutil.rmtree(self.backup_local_storage_dir, True)
|
||||||
|
os.makedirs(self.backup_local_storage_dir)
|
||||||
|
|
||||||
|
self.environ = super(TestFreezerFSBackup, self).get_environ()
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
|
||||||
|
super(TestFreezerFSBackup, self).tearDown()
|
||||||
|
|
||||||
|
shutil.rmtree(self.backup_source_dir, True)
|
||||||
|
shutil.rmtree(self.restore_target_dir, True)
|
||||||
|
shutil.rmtree(self.backup_local_storage_dir)
|
||||||
|
|
||||||
|
|
||||||
|
@test.attr(type="gate")
|
||||||
|
def test_freezer_fs_backup(self):
|
||||||
|
|
||||||
|
backup_args = ['freezer-agent',
|
||||||
|
'--path-to-backup',
|
||||||
|
self.backup_source_dir,
|
||||||
|
'--container',
|
||||||
|
self.backup_local_storage_dir,
|
||||||
|
'--backup-name',
|
||||||
|
self.freezer_backup_name,
|
||||||
|
'--storage',
|
||||||
|
'local']
|
||||||
|
|
||||||
|
output = subprocess.check_output(backup_args,
|
||||||
|
stderr=subprocess.STDOUT,
|
||||||
|
env=self.environ, shell=False)
|
||||||
|
|
||||||
|
restore_args = ['freezer-agent',
|
||||||
|
'--action',
|
||||||
|
'restore',
|
||||||
|
'--restore-abs-path',
|
||||||
|
self.restore_target_dir,
|
||||||
|
'--container',
|
||||||
|
self.backup_local_storage_dir,
|
||||||
|
'--backup-name',
|
||||||
|
self.freezer_backup_name,
|
||||||
|
'--storage',
|
||||||
|
'local']
|
||||||
|
|
||||||
|
output = subprocess.check_output(restore_args,
|
||||||
|
stderr=subprocess.STDOUT,
|
||||||
|
env=self.environ, shell=False)
|
||||||
|
|
||||||
|
diff_args = ['diff',
|
||||||
|
'-r',
|
||||||
|
'-q',
|
||||||
|
self.backup_source_dir,
|
||||||
|
self.restore_target_dir]
|
||||||
|
|
||||||
|
diff_rc = subprocess.call(diff_args,
|
||||||
|
shell=False)
|
||||||
|
|
||||||
|
self.assertEqual(0, diff_rc, "Test backup to local storage and "
|
||||||
|
"restore")
|
|
@ -23,88 +23,89 @@ from tempest import test
|
||||||
|
|
||||||
class TestFreezerSwiftBackup(base.BaseFreezerTest):
|
class TestFreezerSwiftBackup(base.BaseFreezerTest):
|
||||||
|
|
||||||
@test.attr(type="gate")
|
def __init__(self, *args, **kwargs):
|
||||||
def test_freezer_swift_backup(self):
|
|
||||||
|
super(TestFreezerSwiftBackup, self).__init__(*args, **kwargs)
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
|
||||||
|
super(TestFreezerSwiftBackup, self).setUp()
|
||||||
|
|
||||||
now_in_secs = datetime.datetime.now().strftime("%s")
|
now_in_secs = datetime.datetime.now().strftime("%s")
|
||||||
|
|
||||||
backup_source_dir = ("/tmp/freezer-test-backup-source/"
|
self.backup_source_dir = ("/tmp/freezer-test-backup-source/"
|
||||||
+ now_in_secs)
|
+ now_in_secs)
|
||||||
backup_source_sub_dir = backup_source_dir + "/subdir"
|
self.backup_source_sub_dir = self.backup_source_dir + "/subdir"
|
||||||
|
|
||||||
restore_target_dir = (
|
self.restore_target_dir = (
|
||||||
"/tmp/freezer-test-backup-restore/"
|
"/tmp/freezer-test-backup-restore/"
|
||||||
+ now_in_secs)
|
+ now_in_secs)
|
||||||
|
|
||||||
freezer_container_name = 'freezer-test-container-0'
|
self.freezer_container_name = 'freezer-test-container-0'
|
||||||
freezer_backup_name = 'freezer-test-backup-0'
|
self.freezer_backup_name = 'freezer-test-backup-swift-0'
|
||||||
|
|
||||||
shutil.rmtree(backup_source_dir, True)
|
shutil.rmtree(self.backup_source_dir, True)
|
||||||
os.makedirs(backup_source_dir)
|
os.makedirs(self.backup_source_dir)
|
||||||
open(backup_source_dir + "/a", 'w').close()
|
open(self.backup_source_dir + "/a", 'w').close()
|
||||||
open(backup_source_dir + "/b", 'w').close()
|
open(self.backup_source_dir + "/b", 'w').close()
|
||||||
open(backup_source_dir + "/c", 'w').close()
|
open(self.backup_source_dir + "/c", 'w').close()
|
||||||
|
|
||||||
os.makedirs(backup_source_sub_dir)
|
os.makedirs(self.backup_source_sub_dir)
|
||||||
open(backup_source_sub_dir + "/x", 'w').close()
|
open(self.backup_source_sub_dir + "/x", 'w').close()
|
||||||
open(backup_source_sub_dir + "/y", 'w').close()
|
open(self.backup_source_sub_dir + "/y", 'w').close()
|
||||||
open(backup_source_sub_dir + "/z", 'w').close()
|
open(self.backup_source_sub_dir + "/z", 'w').close()
|
||||||
|
|
||||||
shutil.rmtree(restore_target_dir, True)
|
shutil.rmtree(self.restore_target_dir, True)
|
||||||
os.makedirs(restore_target_dir)
|
os.makedirs(self.restore_target_dir)
|
||||||
|
|
||||||
os.environ['OS_REGION_NAME'] = 'RegionOne'
|
self.environ = super(TestFreezerSwiftBackup, self).get_environ()
|
||||||
os.environ['OS_PASSWORD'] = 'secretadmin'
|
|
||||||
os.environ['OS_IDENTITY_API_VERSION'] = '2.0'
|
def tearDown(self):
|
||||||
os.environ['OS_NO_CACHE'] = '1'
|
|
||||||
os.environ['OS_USERNAME'] = 'demo'
|
super(TestFreezerSwiftBackup, self).tearDown()
|
||||||
os.environ['OS_VOLUME_API_VERSION'] = '2'
|
|
||||||
os.environ['OS_PROJECT_NAME'] = 'demo'
|
shutil.rmtree(self.backup_source_dir, True)
|
||||||
os.environ['PYTHONUNBUFFERED'] = '1'
|
shutil.rmtree(self.restore_target_dir, True)
|
||||||
os.environ['OS_TENANT_NAME'] = 'demo'
|
|
||||||
os.environ['OS_TENANT_ID'] = ''
|
|
||||||
os.environ['OS_AUTH_URL'] = 'http://localhost:5000/v2.0'
|
@test.attr(type="gate")
|
||||||
# Mac OS X uses gtar located in /urs/local/bin
|
def test_freezer_swift_backup(self):
|
||||||
os.environ['PATH'] = '/usr/local/bin:' + os.environ['PATH']
|
|
||||||
|
|
||||||
backup_args = ['freezer-agent',
|
backup_args = ['freezer-agent',
|
||||||
'--path-to-backup',
|
'--path-to-backup',
|
||||||
backup_source_dir,
|
self.backup_source_dir,
|
||||||
'--container',
|
'--container',
|
||||||
freezer_container_name,
|
self.freezer_container_name,
|
||||||
'--backup-name',
|
'--backup-name',
|
||||||
freezer_backup_name]
|
self.freezer_backup_name]
|
||||||
|
|
||||||
output = subprocess.check_output(backup_args,
|
output = subprocess.check_output(backup_args,
|
||||||
stderr=subprocess.STDOUT,
|
stderr=subprocess.STDOUT,
|
||||||
env=os.environ, shell=False)
|
env=self.environ, shell=False)
|
||||||
|
|
||||||
restore_args = ['freezer-agent',
|
restore_args = ['freezer-agent',
|
||||||
'--action',
|
'--action',
|
||||||
'restore',
|
'restore',
|
||||||
'--restore-abs-path',
|
'--restore-abs-path',
|
||||||
restore_target_dir,
|
self.restore_target_dir,
|
||||||
'--container',
|
'--container',
|
||||||
freezer_container_name,
|
self.freezer_container_name,
|
||||||
'--backup-name',
|
'--backup-name',
|
||||||
freezer_backup_name,
|
self.freezer_backup_name,
|
||||||
'--storage',
|
'--storage',
|
||||||
'swift']
|
'swift']
|
||||||
|
|
||||||
output = subprocess.check_output(restore_args,
|
output = subprocess.check_output(restore_args,
|
||||||
stderr=subprocess.STDOUT,
|
stderr=subprocess.STDOUT,
|
||||||
env=os.environ, shell=False)
|
env=self.environ, shell=False)
|
||||||
|
|
||||||
diff_args = ['diff',
|
diff_args = ['diff',
|
||||||
'-r',
|
'-r',
|
||||||
'-q',
|
'-q',
|
||||||
backup_source_dir,
|
self.backup_source_dir,
|
||||||
restore_target_dir]
|
self.restore_target_dir]
|
||||||
|
|
||||||
diff_rc = subprocess.call(diff_args,
|
diff_rc = subprocess.call(diff_args,
|
||||||
shell=False)
|
shell=False)
|
||||||
|
|
||||||
self.assertEqual(0, diff_rc, "Test backup to swift and restore")
|
self.assertEqual(0, diff_rc, "Test backup to swift and restore")
|
||||||
|
|
||||||
shutil.rmtree(backup_source_dir, True)
|
|
||||||
shutil.rmtree(restore_target_dir, True)
|
|
||||||
|
|
Loading…
Reference in New Issue