1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-12 16:56:15 +01:00

Fix develproject arg handling

This commit is contained in:
Daniel Mach 2023-01-12 13:44:32 +01:00
parent 19dcb3dc78
commit bce0c3ffe4
2 changed files with 38 additions and 11 deletions

View File

@ -164,12 +164,15 @@ def pop_project_package_from_args(
)
path = Path.cwd()
project_store = None
package_store = None
if project == ".":
# project name taken from the working copy
store = osc_store.Store(path)
project_store = osc_store.Store(path)
try:
store = osc_store.Store(path)
project = store.project
project_store = osc_store.Store(path)
project = project_store.project
except oscerr.NoWorkingCopy:
if not project_is_optional:
raise
@ -178,13 +181,17 @@ def pop_project_package_from_args(
if package == ".":
# package name taken from the working copy
try:
store = osc_store.Store(path)
store.assert_is_package()
package = store.package
package_store = osc_store.Store(path)
package_store.assert_is_package()
package = package_store.package
except oscerr.NoWorkingCopy:
if not package_is_optional:
raise
if package_is_optional:
package = None
elif not project_store and default_package == ".":
# project wasn't retrieved from store, let's ask for specifying a package
raise oscerr.OscValueError("Please specify a package") from None
else:
raise
return project, package
@ -1033,9 +1040,7 @@ class Osc(cmdln.Cmdln):
apiurl = self.get_api_url()
args = list(args)
project, package = pop_project_package_from_args(
args, package_is_optional=False
)
project, package = pop_project_package_from_args(args, default_project=".", default_package=".")
devel_project, devel_package = show_devel_project(apiurl, project, package)

View File

@ -192,6 +192,28 @@ class TestPopProjectPackageFromArgs(unittest.TestCase):
self.assertEqual(package, "store_package")
self.assertEqual(args, [])
def test_project_requires_to_specify_package(self):
args = ["project"]
self.assertRaises(
OscValueError,
pop_project_package_from_args,
args,
default_project=".",
default_package=".",
)
# The project from store is ignored because we've specified one.
# Specifying a package is expected.
self._write_store("store_project")
args = ["project"]
self.assertRaises(
OscValueError,
pop_project_package_from_args,
args,
default_project=".",
default_package=".",
)
class TestPopRepositoryArchFromArgs(unittest.TestCase):
def test_individial_args(self):