2015-12-04 23:58:28 +08:00
|
|
|
from unittest import TestCase
|
|
|
|
from nose.tools import assert_raises
|
2018-09-14 16:14:59 +08:00
|
|
|
from nose.tools import assert_not_equal, assert_in
|
2015-12-06 20:10:54 +08:00
|
|
|
from ..helpers.integration_test_helper import IntegrationTestHelper
|
2015-12-04 23:58:28 +08:00
|
|
|
|
|
|
|
|
2015-12-06 20:10:54 +08:00
|
|
|
class TestAdmin0Functions(TestCase):
|
2015-12-04 23:58:28 +08:00
|
|
|
|
2015-12-06 20:10:54 +08:00
|
|
|
def setUp(self):
|
|
|
|
self.env_variables = IntegrationTestHelper.get_environment_variables()
|
2016-11-07 17:33:15 +08:00
|
|
|
self.sql_api_url = "{0}://{1}.{2}/api/v1/sql".format(
|
|
|
|
self.env_variables['schema'],
|
2015-12-06 20:10:54 +08:00
|
|
|
self.env_variables['username'],
|
|
|
|
self.env_variables['host'],
|
|
|
|
)
|
2015-12-04 23:58:28 +08:00
|
|
|
|
2015-12-06 20:10:54 +08:00
|
|
|
def test_if_select_with_admin0_is_ok(self):
|
2015-12-06 21:53:17 +08:00
|
|
|
query = "SELECT cdb_geocode_admin0_polygon(country) as geometry " \
|
2016-02-24 16:54:00 +08:00
|
|
|
"FROM {0} LIMIT 1&api_key={1}".format(
|
|
|
|
self.env_variables['table_name'],
|
|
|
|
self.env_variables['api_key'])
|
2015-12-06 20:10:54 +08:00
|
|
|
geometry = IntegrationTestHelper.execute_query(self.sql_api_url, query)
|
2016-02-24 16:54:00 +08:00
|
|
|
assert_not_equal(geometry['geometry'], None)
|
2015-12-06 20:30:15 +08:00
|
|
|
|
|
|
|
def test_if_select_with_admin0_without_api_key_raise_error(self):
|
2015-12-06 21:53:17 +08:00
|
|
|
query = "SELECT cdb_geocode_admin0_polygon(country) as geometry " \
|
2016-02-24 16:54:00 +08:00
|
|
|
"FROM {0} LIMIT 1".format(self.env_variables['table_name'])
|
2015-12-06 20:30:15 +08:00
|
|
|
try:
|
|
|
|
IntegrationTestHelper.execute_query(self.sql_api_url, query)
|
|
|
|
except Exception as e:
|
2018-09-14 16:14:59 +08:00
|
|
|
assert_in(e.message[0], ["Geocoding permission denied", "function cdb_geocode_admin0_polygon(text) does not exist"])
|