import unittest from pyoxigraph import * XSD_STRING = NamedNode("http://www.w3.org/2001/XMLSchema#string") XSD_INTEGER = NamedNode("http://www.w3.org/2001/XMLSchema#integer") RDF_LANG_STRING = NamedNode("http://www.w3.org/1999/02/22-rdf-syntax-ns#langString") class TestNamedNode(unittest.TestCase): def test_constructor(self) -> None: self.assertEqual(NamedNode("http://foo").value, "http://foo") def test_string(self) -> None: self.assertEqual(str(NamedNode("http://foo")), "") def test_equal(self) -> None: self.assertEqual(NamedNode("http://foo"), NamedNode("http://foo")) self.assertNotEqual(NamedNode("http://foo"), NamedNode("http://bar")) class TestBlankNode(unittest.TestCase): def test_constructor(self) -> None: self.assertEqual(BlankNode("foo").value, "foo") self.assertNotEqual(BlankNode(), BlankNode()) def test_string(self) -> None: self.assertEqual(str(BlankNode("foo")), "_:foo") def test_equal(self) -> None: self.assertEqual(BlankNode("foo"), BlankNode("foo")) self.assertNotEqual(BlankNode("foo"), BlankNode("bar")) self.assertNotEqual(BlankNode("foo"), NamedNode("http://foo")) self.assertNotEqual(NamedNode("http://foo"), BlankNode("foo")) class TestLiteral(unittest.TestCase): def test_constructor(self) -> None: self.assertEqual(Literal("foo").value, "foo") self.assertEqual(Literal("foo").datatype, XSD_STRING) self.assertEqual(Literal("foo", language="en").value, "foo") self.assertEqual(Literal("foo", language="en").language, "en") self.assertEqual(Literal("foo", language="en").datatype, RDF_LANG_STRING) self.assertEqual(Literal("foo", datatype=XSD_INTEGER).value, "foo") self.assertEqual(Literal("foo", datatype=XSD_INTEGER).datatype, XSD_INTEGER) def test_string(self) -> None: self.assertEqual(str(Literal("foo")), '"foo"') self.assertEqual(str(Literal("foo", language="en")), '"foo"@en') self.assertEqual( str(Literal("foo", datatype=XSD_INTEGER)), '"foo"^^', ) def test_equals(self) -> None: self.assertEqual(Literal("foo", datatype=XSD_STRING), Literal("foo")) self.assertEqual( Literal("foo", language="en", datatype=RDF_LANG_STRING), Literal("foo", language="en"), ) self.assertNotEqual(NamedNode("http://foo"), Literal("foo")) self.assertNotEqual(Literal("foo"), NamedNode("http://foo")) self.assertNotEqual(BlankNode("foo"), Literal("foo")) self.assertNotEqual(Literal("foo"), BlankNode("foo")) class TestTriple(unittest.TestCase): def test_constructor(self) -> None: t = Triple( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), ) self.assertEqual(t.subject, NamedNode("http://example.com/s")) self.assertEqual(t.predicate, NamedNode("http://example.com/p")) self.assertEqual(t.object, NamedNode("http://example.com/o")) def test_rdf_star_constructor(self) -> None: t = Triple( Triple( NamedNode("http://example.com/ss"), NamedNode("http://example.com/sp"), NamedNode("http://example.com/so"), ), NamedNode("http://example.com/p"), Triple( NamedNode("http://example.com/os"), NamedNode("http://example.com/op"), NamedNode("http://example.com/oo"), ), ) self.assertEqual( t.subject, Triple( NamedNode("http://example.com/ss"), NamedNode("http://example.com/sp"), NamedNode("http://example.com/so"), ), ) self.assertEqual(t.predicate, NamedNode("http://example.com/p")) self.assertEqual( t.object, Triple( NamedNode("http://example.com/os"), NamedNode("http://example.com/op"), NamedNode("http://example.com/oo"), ), ) def test_mapping(self) -> None: t = Triple( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), ) self.assertEqual(t[0], NamedNode("http://example.com/s")) self.assertEqual(t[1], NamedNode("http://example.com/p")) self.assertEqual(t[2], NamedNode("http://example.com/o")) def test_destruct(self) -> None: (s, p, o) = Triple( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), ) self.assertEqual(s, NamedNode("http://example.com/s")) self.assertEqual(p, NamedNode("http://example.com/p")) self.assertEqual(o, NamedNode("http://example.com/o")) def test_string(self) -> None: self.assertEqual( str( Triple( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), ) ), " ", ) class TestQuad(unittest.TestCase): def test_constructor(self) -> None: t = Quad( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), NamedNode("http://example.com/g"), ) self.assertEqual(t.subject, NamedNode("http://example.com/s")) self.assertEqual(t.predicate, NamedNode("http://example.com/p")) self.assertEqual(t.object, NamedNode("http://example.com/o")) self.assertEqual(t.graph_name, NamedNode("http://example.com/g")) self.assertEqual( t.triple, Triple( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), ), ) self.assertEqual( Quad( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), ), Quad( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), DefaultGraph(), ), ) def test_mapping(self) -> None: t = Quad( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), NamedNode("http://example.com/g"), ) self.assertEqual(t[0], NamedNode("http://example.com/s")) self.assertEqual(t[1], NamedNode("http://example.com/p")) self.assertEqual(t[2], NamedNode("http://example.com/o")) self.assertEqual(t[3], NamedNode("http://example.com/g")) def test_destruct(self) -> None: (s, p, o, g) = Quad( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), NamedNode("http://example.com/g"), ) self.assertEqual(s, NamedNode("http://example.com/s")) self.assertEqual(p, NamedNode("http://example.com/p")) self.assertEqual(o, NamedNode("http://example.com/o")) self.assertEqual(g, NamedNode("http://example.com/g")) def test_string(self) -> None: self.assertEqual( str( Triple( NamedNode("http://example.com/s"), NamedNode("http://example.com/p"), NamedNode("http://example.com/o"), ) ), " ", ) class TestVariable(unittest.TestCase): def test_constructor(self) -> None: self.assertEqual(Variable("foo").value, "foo") def test_string(self) -> None: self.assertEqual(str(Variable("foo")), "?foo") def test_equal(self) -> None: self.assertEqual(Variable("foo"), Variable("foo")) self.assertNotEqual(Variable("foo"), Variable("bar")) if __name__ == "__main__": unittest.main()