mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-13 01:06:15 +01:00
Merge pull request #1423 from dmach/fix-empty-revisions
Fix testing revision for being empty
This commit is contained in:
commit
19d1bab7b5
@ -1381,7 +1381,7 @@ class Osc(cmdln.Cmdln):
|
|||||||
if li.haserror():
|
if li.haserror():
|
||||||
raise oscerr.LinkExpandError(project, package, li.error)
|
raise oscerr.LinkExpandError(project, package, li.error)
|
||||||
project, package, rev = li.project, li.package, li.rev
|
project, package, rev = li.project, li.package, li.rev
|
||||||
if rev:
|
if not revision_is_empty(rev):
|
||||||
print('# -> %s %s (%s)' % (project, package, rev))
|
print('# -> %s %s (%s)' % (project, package, rev))
|
||||||
else:
|
else:
|
||||||
print('# -> %s %s (latest)' % (project, package))
|
print('# -> %s %s (latest)' % (project, package))
|
||||||
@ -5274,10 +5274,10 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
raise oscerr.WrongOptions('-D | --deleted can only be used with a package')
|
raise oscerr.WrongOptions('-D | --deleted can only be used with a package')
|
||||||
|
|
||||||
rev, dummy = parseRevisionOption(opts.revision)
|
rev, dummy = parseRevisionOption(opts.revision)
|
||||||
if rev is None:
|
if revision_is_empty(rev):
|
||||||
rev = "latest"
|
rev = "latest"
|
||||||
|
|
||||||
if rev and rev != "latest" and not checkRevision(project, package, rev):
|
if not revision_is_empty(rev) and rev != "latest" and not checkRevision(project, package, rev):
|
||||||
print('Revision \'%s\' does not exist' % rev, file=sys.stderr)
|
print('Revision \'%s\' does not exist' % rev, file=sys.stderr)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
@ -7607,7 +7607,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
)
|
)
|
||||||
|
|
||||||
rev, rev_upper = parseRevisionOption(opts.revision)
|
rev, rev_upper = parseRevisionOption(opts.revision)
|
||||||
if rev and not checkRevision(project, package, rev, apiurl, opts.meta):
|
if not revision_is_empty(rev) and not checkRevision(project, package, rev, apiurl, opts.meta):
|
||||||
print('Revision \'%s\' does not exist' % rev, file=sys.stderr)
|
print('Revision \'%s\' does not exist' % rev, file=sys.stderr)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
50
osc/core.py
50
osc/core.py
@ -255,6 +255,10 @@ def os_path_samefile(path1, path2):
|
|||||||
return os.path.realpath(path1) == os.path.realpath(path2)
|
return os.path.realpath(path1) == os.path.realpath(path2)
|
||||||
|
|
||||||
|
|
||||||
|
def revision_is_empty(rev: Union[None, str, int]):
|
||||||
|
return rev in (None, "")
|
||||||
|
|
||||||
|
|
||||||
@total_ordering
|
@total_ordering
|
||||||
class File:
|
class File:
|
||||||
"""represent a file, including its metadata"""
|
"""represent a file, including its metadata"""
|
||||||
@ -2186,7 +2190,7 @@ class Package:
|
|||||||
if add:
|
if add:
|
||||||
diff.append(b'--- %s\t(revision 0)\n' % fname.encode())
|
diff.append(b'--- %s\t(revision 0)\n' % fname.encode())
|
||||||
rev = 'revision 0'
|
rev = 'revision 0'
|
||||||
if revision and fname not in self.to_be_added:
|
if not revision_is_empty(revision) and fname not in self.to_be_added:
|
||||||
rev = 'working copy'
|
rev = 'working copy'
|
||||||
diff.append(b'+++ %s\t(%s)\n' % (fname.encode(), rev.encode()))
|
diff.append(b'+++ %s\t(%s)\n' % (fname.encode(), rev.encode()))
|
||||||
fname = os.path.join(self.absdir, fname)
|
fname = os.path.join(self.absdir, fname)
|
||||||
@ -2194,7 +2198,7 @@ class Package:
|
|||||||
raise oscerr.OscIOError(None, 'file \'%s\' is marked as \'A\' but does not exist\n'
|
raise oscerr.OscIOError(None, 'file \'%s\' is marked as \'A\' but does not exist\n'
|
||||||
'(either add the missing file or revert it)' % fname)
|
'(either add the missing file or revert it)' % fname)
|
||||||
else:
|
else:
|
||||||
if revision:
|
if not revision_is_empty(revision):
|
||||||
b_revision = str(revision).encode()
|
b_revision = str(revision).encode()
|
||||||
else:
|
else:
|
||||||
b_revision = self.rev.encode()
|
b_revision = self.rev.encode()
|
||||||
@ -2205,7 +2209,7 @@ class Package:
|
|||||||
fd = None
|
fd = None
|
||||||
tmpfile = None
|
tmpfile = None
|
||||||
try:
|
try:
|
||||||
if revision is not None and not add:
|
if not revision_is_empty(revision) and not add:
|
||||||
(fd, tmpfile) = tempfile.mkstemp(prefix='osc_diff')
|
(fd, tmpfile) = tempfile.mkstemp(prefix='osc_diff')
|
||||||
get_source_file(self.apiurl, self.prjname, self.name, origname, tmpfile, revision)
|
get_source_file(self.apiurl, self.prjname, self.name, origname, tmpfile, revision)
|
||||||
fname = tmpfile
|
fname = tmpfile
|
||||||
@ -2270,7 +2274,7 @@ class Package:
|
|||||||
continue
|
continue
|
||||||
elif state == ' ' and revision is None:
|
elif state == ' ' and revision is None:
|
||||||
continue
|
continue
|
||||||
elif revision and self.findfilebyname(f.name).md5 == f.md5 and state != 'M':
|
elif not revision_is_empty(revision) and self.findfilebyname(f.name).md5 == f.md5 and state != 'M':
|
||||||
continue
|
continue
|
||||||
yield [diff_hdr % f.name.encode()]
|
yield [diff_hdr % f.name.encode()]
|
||||||
if revision is None:
|
if revision is None:
|
||||||
@ -3698,7 +3702,7 @@ def meta_get_filelist(
|
|||||||
query['expand'] = 1
|
query['expand'] = 1
|
||||||
if meta:
|
if meta:
|
||||||
query['meta'] = 1
|
query['meta'] = 1
|
||||||
if revision:
|
if not revision_is_empty(revision):
|
||||||
query['rev'] = revision
|
query['rev'] = revision
|
||||||
else:
|
else:
|
||||||
query['rev'] = 'latest'
|
query['rev'] = 'latest'
|
||||||
@ -3739,7 +3743,7 @@ def show_project_meta(apiurl: str, prj: str, rev=None, blame=None):
|
|||||||
query = {}
|
query = {}
|
||||||
if blame:
|
if blame:
|
||||||
query['view'] = "blame"
|
query['view'] = "blame"
|
||||||
if rev:
|
if not revision_is_empty(rev):
|
||||||
query['rev'] = rev
|
query['rev'] = rev
|
||||||
url = makeurl(apiurl, ['source', prj, '_project', '_meta'], query)
|
url = makeurl(apiurl, ['source', prj, '_project', '_meta'], query)
|
||||||
try:
|
try:
|
||||||
@ -3765,7 +3769,7 @@ def show_project_meta(apiurl: str, prj: str, rev=None, blame=None):
|
|||||||
def show_project_conf(apiurl: str, prj: str, rev=None, blame=None):
|
def show_project_conf(apiurl: str, prj: str, rev=None, blame=None):
|
||||||
query = {}
|
query = {}
|
||||||
url = None
|
url = None
|
||||||
if rev:
|
if not revision_is_empty(rev):
|
||||||
query['rev'] = rev
|
query['rev'] = rev
|
||||||
if blame:
|
if blame:
|
||||||
query['view'] = "blame"
|
query['view'] = "blame"
|
||||||
@ -4200,11 +4204,11 @@ def show_files_meta(
|
|||||||
deleted=False,
|
deleted=False,
|
||||||
):
|
):
|
||||||
query = {}
|
query = {}
|
||||||
if revision:
|
if not revision_is_empty(revision):
|
||||||
query['rev'] = revision
|
query['rev'] = revision
|
||||||
else:
|
else:
|
||||||
query['rev'] = 'latest'
|
query['rev'] = 'latest'
|
||||||
if linkrev:
|
if not revision_is_empty(linkrev):
|
||||||
query['linkrev'] = linkrev
|
query['linkrev'] = linkrev
|
||||||
elif conf.config['linkcontrol']:
|
elif conf.config['linkcontrol']:
|
||||||
query['linkrev'] = 'base'
|
query['linkrev'] = 'base'
|
||||||
@ -4303,7 +4307,9 @@ def get_project_sourceinfo(apiurl: str, project: str, nofilename: bool, *package
|
|||||||
def show_upstream_rev_vrev(apiurl: str, prj, pac, revision=None, expand=False, meta=False):
|
def show_upstream_rev_vrev(apiurl: str, prj, pac, revision=None, expand=False, meta=False):
|
||||||
m = show_files_meta(apiurl, prj, pac, revision=revision, expand=expand, meta=meta)
|
m = show_files_meta(apiurl, prj, pac, revision=revision, expand=expand, meta=meta)
|
||||||
et = ET.fromstring(m)
|
et = ET.fromstring(m)
|
||||||
return et.get('rev'), et.get('vrev')
|
rev = et.get("rev") or None
|
||||||
|
vrev = et.get("vrev") or None
|
||||||
|
return rev, vrev
|
||||||
|
|
||||||
|
|
||||||
def show_upstream_rev(
|
def show_upstream_rev(
|
||||||
@ -5232,7 +5238,7 @@ def get_source_file(
|
|||||||
query = {}
|
query = {}
|
||||||
if meta:
|
if meta:
|
||||||
query['meta'] = 1
|
query['meta'] = 1
|
||||||
if revision:
|
if not revision_is_empty(revision):
|
||||||
query['rev'] = revision
|
query['rev'] = revision
|
||||||
u = makeurl(
|
u = makeurl(
|
||||||
apiurl,
|
apiurl,
|
||||||
@ -5404,9 +5410,9 @@ def server_diff(
|
|||||||
query['oproject'] = old_project
|
query['oproject'] = old_project
|
||||||
if old_package:
|
if old_package:
|
||||||
query['opackage'] = old_package
|
query['opackage'] = old_package
|
||||||
if old_revision:
|
if not revision_is_empty(old_revision):
|
||||||
query['orev'] = old_revision
|
query['orev'] = old_revision
|
||||||
if new_revision:
|
if not revision_is_empty(new_revision):
|
||||||
query['rev'] = new_revision
|
query['rev'] = new_revision
|
||||||
if unified:
|
if unified:
|
||||||
query['unified'] = 1
|
query['unified'] = 1
|
||||||
@ -5779,7 +5785,7 @@ def link_pac(
|
|||||||
if src_project == dst_project and src_package == dst_package:
|
if src_project == dst_project and src_package == dst_package:
|
||||||
raise oscerr.OscValueError("Cannot link package. Source and target are the same.")
|
raise oscerr.OscValueError("Cannot link package. Source and target are the same.")
|
||||||
|
|
||||||
if rev and not checkRevision(src_project, src_package, rev):
|
if not revision_is_empty(rev) and not checkRevision(src_project, src_package, rev):
|
||||||
raise oscerr.OscValueError(f"Revision doesn't exist: {rev}")
|
raise oscerr.OscValueError(f"Revision doesn't exist: {rev}")
|
||||||
|
|
||||||
meta_change = False
|
meta_change = False
|
||||||
@ -5839,7 +5845,7 @@ def link_pac(
|
|||||||
print('_link file already exists...! Aborting', file=sys.stderr)
|
print('_link file already exists...! Aborting', file=sys.stderr)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
if rev:
|
if not revision_is_empty(rev):
|
||||||
rev = ' rev="%s"' % rev
|
rev = ' rev="%s"' % rev
|
||||||
else:
|
else:
|
||||||
rev = ''
|
rev = ''
|
||||||
@ -6124,9 +6130,9 @@ def branch_pkg(
|
|||||||
query['newinstance'] = "1"
|
query['newinstance'] = "1"
|
||||||
if extend_package_names:
|
if extend_package_names:
|
||||||
query['extend_package_names'] = "1"
|
query['extend_package_names'] = "1"
|
||||||
if rev:
|
if not revision_is_empty(rev):
|
||||||
query['rev'] = rev
|
query['rev'] = rev
|
||||||
if linkrev:
|
if not revision_is_empty(linkrev):
|
||||||
query['linkrev'] = linkrev
|
query['linkrev'] = linkrev
|
||||||
if target_project:
|
if target_project:
|
||||||
query['target_project'] = target_project
|
query['target_project'] = target_project
|
||||||
@ -6232,7 +6238,7 @@ def copy_pac(
|
|||||||
query['expand'] = '1'
|
query['expand'] = '1'
|
||||||
if keep_link:
|
if keep_link:
|
||||||
query['keeplink'] = '1'
|
query['keeplink'] = '1'
|
||||||
if revision:
|
if not revision_is_empty(revision):
|
||||||
query['orev'] = revision
|
query['orev'] = revision
|
||||||
if comment:
|
if comment:
|
||||||
query['comment'] = comment
|
query['comment'] = comment
|
||||||
@ -7113,7 +7119,7 @@ def get_source_rev(apiurl: str, project: str, package: str, revision=None):
|
|||||||
# but not rev=current,rev=latest,rev=top, or anything like this.
|
# but not rev=current,rev=latest,rev=top, or anything like this.
|
||||||
# CAUTION: We have to loop through all rev and find the highest one, if none given.
|
# CAUTION: We have to loop through all rev and find the highest one, if none given.
|
||||||
|
|
||||||
if revision:
|
if not revision_is_empty(revision):
|
||||||
url = makeurl(apiurl, ['source', project, package, '_history'], {'rev': revision})
|
url = makeurl(apiurl, ['source', project, package, '_history'], {'rev': revision})
|
||||||
else:
|
else:
|
||||||
url = makeurl(apiurl, ['source', project, package, '_history'])
|
url = makeurl(apiurl, ['source', project, package, '_history'])
|
||||||
@ -7200,10 +7206,10 @@ def get_commitlog(
|
|||||||
rev = int(node.get('rev'))
|
rev = int(node.get('rev'))
|
||||||
# vrev = int(node.get('vrev')) # what is the meaning of vrev?
|
# vrev = int(node.get('vrev')) # what is the meaning of vrev?
|
||||||
try:
|
try:
|
||||||
if revision is not None and revision_upper is not None:
|
if not revision_is_empty(revision) and revision_upper is not None:
|
||||||
if rev > int(revision_upper) or rev < int(revision):
|
if rev > int(revision_upper) or rev < int(revision):
|
||||||
continue
|
continue
|
||||||
elif revision is not None and rev != int(revision):
|
elif not revision_is_empty(revision) and rev != int(revision):
|
||||||
continue
|
continue
|
||||||
except ValueError:
|
except ValueError:
|
||||||
if revision != srcmd5:
|
if revision != srcmd5:
|
||||||
@ -7753,7 +7759,7 @@ def _set_link_rev(apiurl: str, project: str, package: str, root, revision="", ex
|
|||||||
if revision:
|
if revision:
|
||||||
root.set('rev', revision)
|
root.set('rev', revision)
|
||||||
# add vrev when revision is a srcmd5
|
# add vrev when revision is a srcmd5
|
||||||
if vrev is not None and revision is not None and len(revision) >= 32:
|
if not revision_is_empty(vrev) and not revision_is_empty(revision) and len(revision) >= 32:
|
||||||
root.set('vrev', vrev)
|
root.set('vrev', vrev)
|
||||||
return revision
|
return revision
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user