Skip to content

Commit

Permalink
Merge pull request #427 from msdemlei/improve-regtap-test-coverage
Browse files Browse the repository at this point in the history
Adding minor tests to test_regtap
  • Loading branch information
bsipocz authored Apr 27, 2023
2 parents a897483 + 352ac15 commit b3f3525
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 7 deletions.
21 changes: 14 additions & 7 deletions pyvo/registry/regtap.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@
from astropy.utils.decorators import deprecated
from astropy.utils.exceptions import AstropyDeprecationWarning

import numpy

from . import rtcons
from ..dal import scs, sia, sia2, ssa, sla, tap, query as dalq
from ..io.vosi import vodataservice
Expand Down Expand Up @@ -539,7 +541,11 @@ def region_of_regard(self):
by which a positional query against this resource should be "blurred"
in order to get an appropriate match.
"""
return float(self.get("region_of_regard", 0))
# we get NULLs as NaNs here
val = self["region_of_regard"]
if numpy.isnan(val):
return None
return val

@property
def waveband(self):
Expand Down Expand Up @@ -734,15 +740,16 @@ def search(self, *args, **keys):
Raises
------
RuntimeError
DALServiceError
if the resource does not describe a searchable service.
"""
if not self.service:
try:
return self.service.search(*args, **keys)
except ValueError:
# I blindly assume the ValueError comes out of get_interface.
# But then that's likely enough.
raise dalq.DALServiceError(
"resource, {}, is not a searchable service".format(
self.short_name))

return self.service.search(*args, **keys)
f"Resource {self.ivoid} is not a searchable service")

def describe(self, verbose=False, width=78, file=None):
"""
Expand Down
31 changes: 31 additions & 0 deletions pyvo/registry/tests/test_regtap.py
Original file line number Diff line number Diff line change
Expand Up @@ -383,6 +383,7 @@ def test_record_fields(rt_pulsar_distance):
assert rec.content_types == ['catalog']
assert rec.source_format == "bibcode"
assert rec.source_value == "1993ApJS...88..529T"
assert rec.region_of_regard is None
assert rec.waveband == ['radio']
# access URL, standard_id and friends exercised in TestInterfaceSelection

Expand Down Expand Up @@ -453,6 +454,17 @@ def test_get_web_interface(self, flash_service):
assert (svc.access_url
== "http://dc.zah.uni-heidelberg.de/flashheros/q/web/form")

import webbrowser
orig_open = webbrowser.open
try:
open_args = []
webbrowser.open = lambda *args: open_args.append(args)
svc.search()
assert open_args == [
("http://dc.zah.uni-heidelberg.de/flashheros/q/web/form", 2)]
finally:
webbrowser.open = orig_open

def test_get_aux_interface(self, flash_service):
svc = flash_service.get_service("tap#aux")
assert (svc._baseurl
Expand Down Expand Up @@ -540,6 +552,22 @@ def test_sia2_aux(self):
assert rec.get_interface("sia2").access_url == 'http://sia2.example.com'
assert rec.get_interface("sia").access_url == 'http://sia.example.com'

def test_non_standard_interface(self):
intf = regtap.Interface("http://url", "", "", "")
assert intf.supports("ivo://ivoa.net/std/sia") is False

def test_supports_none(self):
intf = regtap.Interface("http://url", "", "", "")
assert intf.supports(None) is False

def test_non_searchable_service(self):
rec = _makeRegistryRecord()
with pytest.raises(dalq.DALServiceError) as excinfo:
rec.search()

assert str(excinfo.value) == (
"Resource ivo://pyvo/test_regtap.py is not a searchable service")


class _FakeResult:
"""A fake class just sufficient for giving dal.query.Record enough
Expand Down Expand Up @@ -623,6 +651,9 @@ def test_select_single_matching_service(self):
intf_roles=["", "std"])

assert (rsc.service._baseurl == "http://b")
# this makes sure caching the service obtained doesn't break
# things
assert (rsc.service._baseurl == "http://b")

def test_capless(self):
rsc = _makeRegistryRecord()
Expand Down

0 comments on commit b3f3525

Please sign in to comment.