mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-25 16:38:09 +00:00
Adds more tests for the inventaire connector
This commit is contained in:
parent
6ba605cbd0
commit
07446fa7d2
2 changed files with 121 additions and 3 deletions
|
@ -104,9 +104,7 @@ class Connector(AbstractConnector):
|
||||||
|
|
||||||
def parse_isbn_search_data(self, data):
|
def parse_isbn_search_data(self, data):
|
||||||
"""got some daaaata"""
|
"""got some daaaata"""
|
||||||
results = data.get("entities")
|
results = data.get("entities", [])
|
||||||
if not results:
|
|
||||||
return []
|
|
||||||
return list(results.values())
|
return list(results.values())
|
||||||
|
|
||||||
def format_isbn_search_result(self, search_result):
|
def format_isbn_search_result(self, search_result):
|
||||||
|
@ -128,6 +126,7 @@ class Connector(AbstractConnector):
|
||||||
|
|
||||||
def load_edition_data(self, work_uri):
|
def load_edition_data(self, work_uri):
|
||||||
"""get a list of editions for a work"""
|
"""get a list of editions for a work"""
|
||||||
|
# pylint: disable=line-too-long
|
||||||
url = f"{self.books_url}?action=reverse-claims&property=wdt:P629&value={work_uri}&sort=true"
|
url = f"{self.books_url}?action=reverse-claims&property=wdt:P629&value={work_uri}&sort=true"
|
||||||
return get_data(url)
|
return get_data(url)
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,14 @@
|
||||||
""" testing book data connectors """
|
""" testing book data connectors """
|
||||||
import json
|
import json
|
||||||
import pathlib
|
import pathlib
|
||||||
|
from unittest.mock import patch
|
||||||
|
|
||||||
from django.test import TestCase
|
from django.test import TestCase
|
||||||
import responses
|
import responses
|
||||||
|
|
||||||
from bookwyrm import models
|
from bookwyrm import models
|
||||||
from bookwyrm.connectors.inventaire import Connector, get_language_code
|
from bookwyrm.connectors.inventaire import Connector, get_language_code
|
||||||
|
from bookwyrm.connectors.connector_manager import ConnectorException
|
||||||
|
|
||||||
|
|
||||||
class Inventaire(TestCase):
|
class Inventaire(TestCase):
|
||||||
|
@ -48,6 +51,44 @@ class Inventaire(TestCase):
|
||||||
self.assertEqual(result["wdt:P31"], ["wd:Q3331189"])
|
self.assertEqual(result["wdt:P31"], ["wd:Q3331189"])
|
||||||
self.assertEqual(result["uri"], "isbn:9780375757853")
|
self.assertEqual(result["uri"], "isbn:9780375757853")
|
||||||
|
|
||||||
|
@responses.activate
|
||||||
|
def test_get_book_data_invalid(self):
|
||||||
|
"""error if there isn't any entity data"""
|
||||||
|
responses.add(
|
||||||
|
responses.GET,
|
||||||
|
"https://test.url/ok",
|
||||||
|
json={
|
||||||
|
"entities": {},
|
||||||
|
"redirects": {},
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
with self.assertRaises(ConnectorException):
|
||||||
|
self.connector.get_book_data("https://test.url/ok")
|
||||||
|
|
||||||
|
@responses.activate
|
||||||
|
def test_search(self):
|
||||||
|
"""min confidence filtering"""
|
||||||
|
responses.add(
|
||||||
|
responses.GET,
|
||||||
|
"https://inventaire.io/search?q=hi",
|
||||||
|
json={
|
||||||
|
"results": [
|
||||||
|
{
|
||||||
|
"_score": 200,
|
||||||
|
"label": "hello",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"_score": 100,
|
||||||
|
"label": "hi",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
)
|
||||||
|
results = self.connector.search("hi", min_confidence=0.5)
|
||||||
|
self.assertEqual(len(results), 1)
|
||||||
|
self.assertEqual(results[0].title, "hello")
|
||||||
|
|
||||||
def test_format_search_result(self):
|
def test_format_search_result(self):
|
||||||
"""json to search result objs"""
|
"""json to search result objs"""
|
||||||
search_file = pathlib.Path(__file__).parent.joinpath(
|
search_file = pathlib.Path(__file__).parent.joinpath(
|
||||||
|
@ -157,6 +198,84 @@ class Inventaire(TestCase):
|
||||||
"https://covers.inventaire.io/img/entities/12345",
|
"https://covers.inventaire.io/img/entities/12345",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def test_isbn_search_empty(self):
|
||||||
|
"""another search type"""
|
||||||
|
search_results = {}
|
||||||
|
results = self.connector.parse_isbn_search_data(search_results)
|
||||||
|
self.assertEqual(results, [])
|
||||||
|
|
||||||
|
def test_isbn_search_no_title(self):
|
||||||
|
"""another search type"""
|
||||||
|
search_file = pathlib.Path(__file__).parent.joinpath(
|
||||||
|
"../data/inventaire_isbn_search.json"
|
||||||
|
)
|
||||||
|
search_results = json.loads(search_file.read_bytes())
|
||||||
|
search_results["entities"]["isbn:9782290349229"]["claims"]["wdt:P1476"] = None
|
||||||
|
|
||||||
|
result = self.connector.format_isbn_search_result(
|
||||||
|
search_results.get("entities")
|
||||||
|
)
|
||||||
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
def test_is_work_data(self):
|
||||||
|
"""is it a work"""
|
||||||
|
work_file = pathlib.Path(__file__).parent.joinpath(
|
||||||
|
"../data/inventaire_work.json"
|
||||||
|
)
|
||||||
|
work_data = json.loads(work_file.read_bytes())
|
||||||
|
with patch("bookwyrm.connectors.inventaire.get_data") as get_data_mock:
|
||||||
|
get_data_mock.return_value = work_data
|
||||||
|
formatted = self.connector.get_book_data("hi")
|
||||||
|
self.assertTrue(self.connector.is_work_data(formatted))
|
||||||
|
|
||||||
|
edition_file = pathlib.Path(__file__).parent.joinpath(
|
||||||
|
"../data/inventaire_edition.json"
|
||||||
|
)
|
||||||
|
edition_data = json.loads(edition_file.read_bytes())
|
||||||
|
with patch("bookwyrm.connectors.inventaire.get_data") as get_data_mock:
|
||||||
|
get_data_mock.return_value = edition_data
|
||||||
|
formatted = self.connector.get_book_data("hi")
|
||||||
|
self.assertFalse(self.connector.is_work_data(formatted))
|
||||||
|
|
||||||
|
@responses.activate
|
||||||
|
def test_get_edition_from_work_data(self):
|
||||||
|
"""load edition"""
|
||||||
|
responses.add(
|
||||||
|
responses.GET,
|
||||||
|
"https://inventaire.io/?action=by-uris&uris=hello",
|
||||||
|
json={"entities": {}},
|
||||||
|
)
|
||||||
|
data = {"uri": "blah"}
|
||||||
|
with patch(
|
||||||
|
"bookwyrm.connectors.inventaire.Connector.load_edition_data"
|
||||||
|
) as loader_mock, patch(
|
||||||
|
"bookwyrm.connectors.inventaire.Connector.get_book_data"
|
||||||
|
) as getter_mock:
|
||||||
|
loader_mock.return_value = {"uris": ["hello"]}
|
||||||
|
self.connector.get_edition_from_work_data(data)
|
||||||
|
self.assertTrue(getter_mock.called)
|
||||||
|
|
||||||
|
with patch(
|
||||||
|
"bookwyrm.connectors.inventaire.Connector.load_edition_data"
|
||||||
|
) as loader_mock:
|
||||||
|
loader_mock.return_value = {"uris": []}
|
||||||
|
with self.assertRaises(ConnectorException):
|
||||||
|
self.connector.get_edition_from_work_data(data)
|
||||||
|
|
||||||
|
@responses.activate
|
||||||
|
def test_get_work_from_edition_data(self):
|
||||||
|
"""load work"""
|
||||||
|
responses.add(
|
||||||
|
responses.GET,
|
||||||
|
"https://inventaire.io/?action=by-uris&uris=hello",
|
||||||
|
)
|
||||||
|
data = {"wdt:P629": "hello"}
|
||||||
|
self.connector.get_work_from_edition_data(data)
|
||||||
|
|
||||||
|
data = {"wdt:P629": None}
|
||||||
|
with self.assertRaises(ConnectorException):
|
||||||
|
self.connector.get_work_from_edition_data(data)
|
||||||
|
|
||||||
def test_get_language_code(self):
|
def test_get_language_code(self):
|
||||||
"""get english or whatever is in reach"""
|
"""get english or whatever is in reach"""
|
||||||
options = {
|
options = {
|
||||||
|
|
Loading…
Reference in a new issue