dataservices-api/test/integration/test_isolines_functions.py
2018-09-14 10:14:59 +02:00

46 lines
2.2 KiB
Python

from unittest import TestCase
from nose.tools import assert_raises
from nose.tools import assert_not_equal, assert_in
from ..helpers.integration_test_helper import IntegrationTestHelper
class TestIsolinesFunctions(TestCase):
def setUp(self):
self.env_variables = IntegrationTestHelper.get_environment_variables()
self.sql_api_url = "{0}://{1}.{2}/api/v1/sql".format(
self.env_variables['schema'],
self.env_variables['username'],
self.env_variables['host'],
)
def test_if_select_with_isochrones_is_ok(self):
query = "SELECT * FROM cdb_isochrone('POINT(-3.70568 40.42028)'::geometry, " \
"'car', ARRAY[300]::integer[]);&api_key={0}".format(
self.env_variables['api_key'])
isolines = IntegrationTestHelper.execute_query(self.sql_api_url, query)
assert_not_equal(isolines['the_geom'], None)
def test_if_select_with_isochrones_without_api_key_raise_error(self):
query = "SELECT * FROM cdb_isochrone('POINT(-3.70568 40.42028)'::geometry, " \
"'car', ARRAY[300]::integer[]);"
try:
IntegrationTestHelper.execute_query(self.sql_api_url, query)
except Exception as e:
assert_in(e.message[0], ["Isolines permission denied", "function cdb_isochrone(geometry, unknown, integer[]) does not exist"])
def test_if_select_with_isodistance_is_ok(self):
query = "SELECT * FROM cdb_isodistance('POINT(-3.70568 40.42028)'::geometry, " \
"'car', ARRAY[300]::integer[]);&api_key={0}".format(
self.env_variables['api_key'])
isolines = IntegrationTestHelper.execute_query(self.sql_api_url, query)
assert_not_equal(isolines['the_geom'], None)
def test_if_select_with_isodistance_without_api_key_raise_error(self):
query = "SELECT * FROM cdb_isodistance('POINT(-3.70568 40.42028)'::geometry, " \
"'car', ARRAY[300]::integer[]);"
try:
IntegrationTestHelper.execute_query(self.sql_api_url, query)
except Exception as e:
assert_in(e.message[0], ["Isolines permission denied", "function cdb_isodistance(geometry, unknown, integer[]) does not exist"])