Source code for sqlobject.tests.test_jsoncol
import pytest
from sqlobject import SQLObject, JSONCol
from sqlobject.tests.dbtest import setupClass
[docs]class JSONTest(SQLObject):
    json = JSONCol(default=None) 
_json_test_data = (
    None, True, 1, 2.0,
    {u"test": [None, True, 1, 2.0,
     {u"unicode'with'apostrophes": u"unicode\"with\"quotes"},
     [],
     u"unicode"]},
    [None, True, 1, 2.0,
     [],
     {u"unicode'with'apostrophes": u"unicode\"with\"quotes"},
     u"unicode", u"unicode'with'apostrophes", u"unicode\"with\"quotes",
     ],
    u"unicode", u"unicode'with'apostrophes", u"unicode\"with\"quotes",
    {'test': 'Test'},
)
def _setup():
    setupClass(JSONTest)
    for _id, test_data in enumerate(_json_test_data):
        JSONTest(id=_id + 1, json=test_data)
[docs]def test_JSONCol():
    _setup()
    JSONTest._connection.cache.clear()
    for _id, test_data in enumerate(_json_test_data):
        json = JSONTest.get(_id + 1)
        assert json.json == test_data 
[docs]def test_JSONCol_funcs():
    connection = JSONTest._connection
    if not hasattr(connection, 'can_use_json_funcs') \
            
or not connection.can_use_json_funcs():
        pytest.skip(
            "The database doesn't support JSON functions; "
            "JSON functions are supported by MariaDB since version 10.2.7 "
            "and by MySQL since version 5.7.")
    _setup()
    rows = list(
        JSONTest.select(JSONTest.q.json.json_extract('test') == 'Test')
    )
    assert len(rows) == 1
    assert rows[0].json == {'test': 'Test'}