Add CreateFileWithContent fixture
Add a fixture for creating real files on the filesystem with contents, to replace the implementation inside the test base class. Blueprint oslotest-refactor-test-base-class Change-Id: Ibca716d1054da973583e5bb4694ef1d64750d50a
This commit is contained in:
parent
5f63439ee7
commit
cc57067355
@ -10,6 +10,13 @@ oslotest.base
|
||||
.. autoclass:: oslotest.base.BaseTestCase
|
||||
:members:
|
||||
|
||||
oslotest.createfile
|
||||
===================
|
||||
|
||||
.. automodule:: oslotest.createfile
|
||||
:members:
|
||||
:special-members:
|
||||
|
||||
oslotest.log
|
||||
============
|
||||
|
||||
|
@ -15,15 +15,12 @@
|
||||
|
||||
"""Common utilities used in testing"""
|
||||
|
||||
import os
|
||||
import tempfile
|
||||
|
||||
import fixtures
|
||||
from oslotest import createfile
|
||||
from oslotest import log
|
||||
from oslotest import output
|
||||
from oslotest import timeout
|
||||
|
||||
import six
|
||||
from six.moves import mock
|
||||
import testtools
|
||||
|
||||
@ -128,16 +125,11 @@ class BaseTestCase(testtools.TestCase):
|
||||
else:
|
||||
basename, contents = f
|
||||
encoding = default_encoding
|
||||
if isinstance(contents, six.text_type):
|
||||
contents = contents.encode(encoding)
|
||||
if not os.path.isabs(basename):
|
||||
(fd, path) = tempfile.mkstemp(prefix=basename, suffix=ext)
|
||||
else:
|
||||
path = basename + ext
|
||||
fd = os.open(path, os.O_CREAT | os.O_WRONLY)
|
||||
tempfiles.append(path)
|
||||
try:
|
||||
os.write(fd, contents)
|
||||
finally:
|
||||
os.close(fd)
|
||||
fix = self.useFixture(createfile.CreateFileWithContent(
|
||||
filename=basename,
|
||||
contents=contents,
|
||||
ext=ext,
|
||||
encoding=encoding,
|
||||
))
|
||||
tempfiles.append(fix.path)
|
||||
return tempfiles
|
||||
|
70
oslotest/createfile.py
Normal file
70
oslotest/createfile.py
Normal file
@ -0,0 +1,70 @@
|
||||
# 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 tempfile
|
||||
|
||||
import fixtures
|
||||
import six
|
||||
|
||||
|
||||
class CreateFileWithContent(fixtures.Fixture):
|
||||
"""Create a temporary file with the given content.
|
||||
|
||||
Creates a file using a predictable name, to be used by tests for
|
||||
code that need a filename to load data or otherwise interact with
|
||||
the real filesystem.
|
||||
|
||||
.. warning::
|
||||
|
||||
It is the responsibility of the caller to ensure that the file
|
||||
is removed.
|
||||
|
||||
Users of this fixture may also want to use
|
||||
:class:`fixtures.NestedTempfile` to set the temporary directory
|
||||
somewhere safe and to ensure the files are cleaned up.
|
||||
|
||||
.. py:attribute:: path
|
||||
|
||||
The canonical name of the file created.
|
||||
|
||||
:param filename: Base file name or full literal path to the file
|
||||
to be created.
|
||||
:param contents: The data to write to the file. Unicode data will
|
||||
be encoded before being written.
|
||||
:param ext: An extension to add to filename.
|
||||
:param encoding: An encoding to use for unicode data (ignored for
|
||||
byte strings).
|
||||
|
||||
"""
|
||||
|
||||
def __init__(self, filename, contents, ext='.conf', encoding='utf-8'):
|
||||
self._filename = filename
|
||||
self._contents = contents
|
||||
self._ext = ext
|
||||
self._encoding = encoding
|
||||
|
||||
def setUp(self):
|
||||
super(CreateFileWithContent, self).setUp()
|
||||
contents = self._contents
|
||||
if isinstance(contents, six.text_type):
|
||||
contents = contents.encode(self._encoding)
|
||||
if not os.path.isabs(self._filename):
|
||||
(fd, self.path) = tempfile.mkstemp(prefix=self._filename,
|
||||
suffix=self._ext)
|
||||
else:
|
||||
self.path = self._filename + self._ext
|
||||
fd = os.open(self.path, os.O_CREAT | os.O_WRONLY)
|
||||
try:
|
||||
os.write(fd, contents)
|
||||
finally:
|
||||
os.close(fd)
|
62
tests/unit/test_createfile.py
Normal file
62
tests/unit/test_createfile.py
Normal file
@ -0,0 +1,62 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright 2014 Deutsche Telekom AG
|
||||
#
|
||||
# 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 six
|
||||
|
||||
from oslotest import base
|
||||
from oslotest import createfile
|
||||
|
||||
|
||||
class CreateFileWithContentTest(base.BaseTestCase):
|
||||
|
||||
def test_create_unicode_files(self):
|
||||
f = createfile.CreateFileWithContent(
|
||||
"no_approve",
|
||||
u'ಠ_ಠ',
|
||||
)
|
||||
f.setUp()
|
||||
with open(f.path, 'rb') as f:
|
||||
contents = f.read()
|
||||
self.assertEqual(u'ಠ_ಠ', six.text_type(contents, encoding='utf-8'))
|
||||
|
||||
def test_create_unicode_files_encoding(self):
|
||||
f = createfile.CreateFileWithContent(
|
||||
"embarrassed", u'⊙﹏⊙', encoding='utf-8',
|
||||
)
|
||||
f.setUp()
|
||||
with open(f.path, 'rb') as f:
|
||||
contents = f.read()
|
||||
self.assertEqual(u'⊙﹏⊙', six.text_type(contents, encoding='utf-8'))
|
||||
|
||||
def test_create_bad_encoding(self):
|
||||
f = createfile.CreateFileWithContent(
|
||||
"hrm", u'ಠ~ಠ', encoding='ascii',
|
||||
)
|
||||
self.assertRaises(UnicodeError, f.setUp)
|
||||
|
||||
def test_prefix(self):
|
||||
f = createfile.CreateFileWithContent('testing', '')
|
||||
f.setUp()
|
||||
basename = os.path.basename(f.path)
|
||||
self.assertTrue(basename.startswith('testing'))
|
||||
|
||||
def test_ext(self):
|
||||
f = createfile.CreateFileWithContent('testing', '', ext='.ending')
|
||||
f.setUp()
|
||||
basename = os.path.basename(f.path)
|
||||
self.assertTrue(basename.endswith('.ending'))
|
Loading…
x
Reference in New Issue
Block a user