mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-25 22:36:13 +01:00
Merge pull request #1586 from dmach/ro-tests
Fix tests so they don't modify fixtures
This commit is contained in:
commit
73662270ea
1
.github/workflows/build-install.yaml
vendored
1
.github/workflows/build-install.yaml
vendored
@ -17,6 +17,7 @@ concurrency:
|
||||
jobs:
|
||||
rpmbuild:
|
||||
name: 'rpmbuild test'
|
||||
needs: unit-ro
|
||||
runs-on: 'ubuntu-latest'
|
||||
strategy:
|
||||
fail-fast: false
|
||||
|
26
.github/workflows/tests.yaml
vendored
26
.github/workflows/tests.yaml
vendored
@ -14,8 +14,34 @@ concurrency:
|
||||
cancel-in-progress: true
|
||||
|
||||
jobs:
|
||||
unit-ro:
|
||||
name: "unit - read only fixtures"
|
||||
runs-on: 'ubuntu-latest'
|
||||
strategy:
|
||||
fail-fast: false
|
||||
|
||||
steps:
|
||||
- name: 'Install packages'
|
||||
run: |
|
||||
sudo apt-get -y update
|
||||
sudo apt-get -y --no-install-recommends install git-lfs
|
||||
sudo apt-get -y --no-install-recommends install diffstat diffutils git-core python3 python3-cryptography python3-pip python3-rpm python3-setuptools python3-urllib3
|
||||
|
||||
- uses: actions/checkout@v3
|
||||
|
||||
- name: 'Change owner to root:root'
|
||||
run: |
|
||||
sudo chown -R root:root tests
|
||||
|
||||
- name: 'Run unit tests'
|
||||
run: |
|
||||
pip3 config set global.break-system-packages 1
|
||||
pip3 install -e .
|
||||
python3 setup.py test
|
||||
|
||||
unit:
|
||||
name: "unit"
|
||||
needs: unit-ro
|
||||
runs-on: 'ubuntu-latest'
|
||||
strategy:
|
||||
fail-fast: false
|
||||
|
@ -1875,7 +1875,7 @@ def get_config(override_conffile=None,
|
||||
os.chmod(conffile, 0o600)
|
||||
except OSError as e:
|
||||
if e.errno in (errno.EROFS, errno.EPERM):
|
||||
print(f"Warning: Configuration file '{conffile}' may have insecure file permissions.")
|
||||
print(f"Warning: Configuration file '{conffile}' may have insecure file permissions.", file=sys.stderr)
|
||||
else:
|
||||
raise e
|
||||
|
||||
|
@ -16,15 +16,10 @@ def suite():
|
||||
|
||||
class TestInitPackage(OscTestCase):
|
||||
def _get_fixtures_dir(self):
|
||||
# workaround for git because it doesn't allow empty dirs
|
||||
if not os.path.exists(os.path.join(FIXTURES_DIR, 'osctest')):
|
||||
os.mkdir(os.path.join(FIXTURES_DIR, 'osctest'))
|
||||
return FIXTURES_DIR
|
||||
|
||||
def tearDown(self):
|
||||
if os.path.exists(os.path.join(FIXTURES_DIR, 'osctest')):
|
||||
os.rmdir(os.path.join(FIXTURES_DIR, 'osctest'))
|
||||
super().tearDown()
|
||||
def setUp(self):
|
||||
super().setUp(copytree=False)
|
||||
|
||||
def test_simple(self):
|
||||
"""initialize a package dir"""
|
||||
|
@ -17,15 +17,10 @@ def suite():
|
||||
|
||||
class TestInitProject(OscTestCase):
|
||||
def _get_fixtures_dir(self):
|
||||
# workaround for git because it doesn't allow empty dirs
|
||||
if not os.path.exists(os.path.join(FIXTURES_DIR, 'osctest')):
|
||||
os.mkdir(os.path.join(FIXTURES_DIR, 'osctest'))
|
||||
return FIXTURES_DIR
|
||||
|
||||
def tearDown(self):
|
||||
if os.path.exists(os.path.join(FIXTURES_DIR, 'osctest')):
|
||||
os.rmdir(os.path.join(FIXTURES_DIR, 'osctest'))
|
||||
super().tearDown()
|
||||
def setUp(self):
|
||||
super().setUp(copytree=False)
|
||||
|
||||
def test_simple(self):
|
||||
"""initialize a project dir"""
|
||||
|
@ -1,6 +1,8 @@
|
||||
import os
|
||||
import re
|
||||
import shutil
|
||||
import sys
|
||||
import tempfile
|
||||
import unittest
|
||||
|
||||
import osc.commandline
|
||||
@ -50,6 +52,18 @@ def suite():
|
||||
class TestProjectDiff(OscTestCase):
|
||||
diff_hdr = 'Index: %s\n==================================================================='
|
||||
|
||||
def setUp(self, copytree=True):
|
||||
super().setUp(copytree=copytree)
|
||||
self.tmpdir_fixtures = tempfile.mkdtemp(prefix='osc_test')
|
||||
shutil.copytree(self._get_fixtures_dir(), os.path.join(self.tmpdir_fixtures, "fixtures"))
|
||||
|
||||
def tearDown(self):
|
||||
try:
|
||||
shutil.rmtree(self.tmpdir_fixtures)
|
||||
except:
|
||||
pass
|
||||
super().tearDown()
|
||||
|
||||
def _get_fixtures_dir(self):
|
||||
return FIXTURES_DIR
|
||||
|
||||
@ -85,10 +99,10 @@ identical: only-in-new
|
||||
os.chdir('/tmp')
|
||||
self.assertRaises(osc.oscerr.WrongArgs, runner)
|
||||
|
||||
self._change_to_tmpdir(FIXTURES_DIR, UPSTREAM)
|
||||
self._change_to_tmpdir(self.tmpdir_fixtures, "fixtures", UPSTREAM)
|
||||
self.assertRaises(osc.oscerr.WrongArgs, runner)
|
||||
|
||||
self._change_to_tmpdir(FIXTURES_DIR, BRANCH)
|
||||
self._change_to_tmpdir(self.tmpdir_fixtures, "fixtures", BRANCH)
|
||||
out = self._run_prdiff()
|
||||
self.assertEqualMultiline(out, exp)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user