Created helper to be used in all the tests
This commit is contained in:
parent
1397b3fcaf
commit
f552f2db12
0
test/__init__.py
Normal file
0
test/__init__.py
Normal file
0
test/helpers/__init__.py
Normal file
0
test/helpers/__init__.py
Normal file
30
test/helpers/integration_test_helper.py
Normal file
30
test/helpers/integration_test_helper.py
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
import os
|
||||||
|
import requests
|
||||||
|
import json
|
||||||
|
|
||||||
|
class IntegrationTestHelper:
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_environment_variables(cls):
|
||||||
|
username = os.environ["GEOCODER_API_TEST_USERNAME"]
|
||||||
|
api_key = os.environ["GEOCODER_API_TEST_API_KEY"]
|
||||||
|
host = os.environ["GEOCODER_API_TEST_HOST"]
|
||||||
|
table_name = os.environ["GEOCODER_API_TEST_TABLE_NAME"]
|
||||||
|
|
||||||
|
return {
|
||||||
|
"username": username,
|
||||||
|
"api_key": api_key,
|
||||||
|
"host": host,
|
||||||
|
"table_name": table_name
|
||||||
|
}
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def execute_query(cls, sql_api_url, query):
|
||||||
|
query_url = "{0}&q={1}".format(sql_api_url, query)
|
||||||
|
print "Executing query: {0}".format(query_url)
|
||||||
|
query_response = requests.get(query_url)
|
||||||
|
if query_response.status_code != 200:
|
||||||
|
raise Exception("Error executing SQL API query")
|
||||||
|
query_response_data = json.loads(query_response.text)
|
||||||
|
|
||||||
|
return query_response_data['rows'][0]['geometry']
|
0
test/integration/__init__.py
Normal file
0
test/integration/__init__.py
Normal file
@ -1,29 +1,22 @@
|
|||||||
import os, time, requests, json
|
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
from nose.tools import assert_raises
|
from nose.tools import assert_raises
|
||||||
|
from nose.tools import assert_not_equal
|
||||||
|
from ..helpers.integration_test_helper import IntegrationTestHelper
|
||||||
|
|
||||||
|
|
||||||
class TestConfigHelper(TestCase):
|
class TestAdmin0Functions(TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
username = os.environ["GEOCODER_API_TEST_USERNAME"]
|
self.env_variables = IntegrationTestHelper.get_environment_variables()
|
||||||
api_key = os.environ["GEOCODER_API_TEST_API_KEY"]
|
self.sql_api_url = "https://{0}.{1}/api/v2/sql?api_key={2}".format(
|
||||||
host = os.environ["GEOCODER_API_TEST_HOST"]
|
self.env_variables['username'],
|
||||||
self.table_name = os.environ["GEOCODER_API_TEST_TABLE_NAME"]
|
self.env_variables['host'],
|
||||||
self.sql_api_url = "https://{0}.{1}/api/v2/sql?api_key={2}".format(username, host, api_key)
|
self.env_variables['api_key']
|
||||||
|
)
|
||||||
|
|
||||||
def test_if_select_with_admin0_is_ok(self):
|
def test_if_select_with_admin0_is_ok(self):
|
||||||
query = "SELECT cdb_geocode_admin0_polygon(name) as geometry FROM {0} LIMIT 1".format(self.table_name)
|
query = "SELECT cdb_geocode_admin0_polygon(name) as geometry " \
|
||||||
geometry = self.execute_query(query)
|
"FROM {0} LIMIT 1".format(
|
||||||
assert geometry != None
|
self.env_variables['table_name'])
|
||||||
|
geometry = IntegrationTestHelper.execute_query(self.sql_api_url, query)
|
||||||
def build_sql_api_query_url(self, query):
|
assert_not_equal(geometry, None)
|
||||||
return "{0}&q={1}".format(self.sql_api_url,query)
|
|
||||||
|
|
||||||
def execute_query(self, query):
|
|
||||||
query_url = self.build_sql_api_query_url(query)
|
|
||||||
query_response = requests.get(query_url)
|
|
||||||
if query_response.status_code != 200:
|
|
||||||
raise Exception("Error executing SQL API query")
|
|
||||||
query_response_data = json.loads(query_response.text)
|
|
||||||
return query_response_data['rows'][0]['geometry']
|
|
||||||
|
@ -1,11 +1,18 @@
|
|||||||
import getopt, sys, requests, time, json, subprocess, os
|
import getopt
|
||||||
|
import sys
|
||||||
|
import requests
|
||||||
|
import time
|
||||||
|
import json
|
||||||
|
import subprocess
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
opts, args = getopt.getopt(sys.argv[1:], "h", ["help", "host="])
|
opts, args = getopt.getopt(sys.argv[1:], "h", ["help", "host="])
|
||||||
|
|
||||||
if len(args) < 2:
|
if len(args) < 2:
|
||||||
usage()
|
usage()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
|
|
||||||
host = "cartodb.com"
|
host = "cartodb.com"
|
||||||
username = args[0]
|
username = args[0]
|
||||||
@ -16,76 +23,95 @@ def main():
|
|||||||
usage()
|
usage()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
elif o in ("--host"):
|
elif o in ("--host"):
|
||||||
host = opts[0][1]
|
host = opts[0][1]
|
||||||
else:
|
else:
|
||||||
assert False, "unhandled option"
|
assert False, "unhandled option"
|
||||||
|
|
||||||
try:
|
try:
|
||||||
table_name = import_test_dataset(username, api_key, host)
|
table_name = import_test_dataset(username, api_key, host)
|
||||||
set_environment_variables(username, api_key, table_name, host)
|
set_environment_variables(username, api_key, table_name, host)
|
||||||
execute_tests()
|
execute_tests()
|
||||||
finally:
|
finally:
|
||||||
clean_environment_variables()
|
clean_environment_variables()
|
||||||
clean_test_dataset(username, api_key, table_name, host)
|
clean_test_dataset(username, api_key, table_name, host)
|
||||||
|
|
||||||
|
|
||||||
def usage():
|
def usage():
|
||||||
print """Usage: run_tests.py [options] username api_key
|
print """Usage: run_tests.py [options] username api_key
|
||||||
Options:
|
Options:
|
||||||
-h: Show this help
|
-h: Show this help
|
||||||
--host: take that host as base (by default is cartodb.com). Eg. cartodb.com"""
|
--host: take that host as base (by default is cartodb.com)"""
|
||||||
|
|
||||||
|
|
||||||
def import_test_dataset(username, api_key, host):
|
def import_test_dataset(username, api_key, host):
|
||||||
url = "https://{0}.{1}/api/v1/imports/?api_key={2}".format(username, host, api_key)
|
url = "https://{0}.{1}/api/v1/imports/?api_key={2}".format(
|
||||||
dataset = {'file': open('fixtures/geocoder_api_test_dataset.csv', 'rb')}
|
username, host, api_key
|
||||||
response = requests.post(url, files=dataset)
|
)
|
||||||
response_json = json.loads(response.text)
|
dataset = {'file': open('fixtures/geocoder_api_test_dataset.csv', 'rb')}
|
||||||
if not response_json['success']:
|
response = requests.post(url, files=dataset)
|
||||||
print "Error importing the test dataset: {0}".format(response.text)
|
response_json = json.loads(response.text)
|
||||||
sys.exit(1)
|
if not response_json['success']:
|
||||||
while(True):
|
print "Error importing the test dataset: {0}".format(response.text)
|
||||||
table_name = get_imported_table_name(username, host, api_key, response_json['item_queue_id'])
|
sys.exit(1)
|
||||||
if table_name:
|
while(True):
|
||||||
return table_name
|
table_name = get_imported_table_name(
|
||||||
else:
|
username,
|
||||||
time.sleep(5)
|
host,
|
||||||
|
api_key,
|
||||||
|
response_json['item_queue_id']
|
||||||
|
)
|
||||||
|
if table_name:
|
||||||
|
return table_name
|
||||||
|
else:
|
||||||
|
time.sleep(5)
|
||||||
|
|
||||||
|
|
||||||
def get_imported_table_name(username, host, api_key, import_id):
|
def get_imported_table_name(username, host, api_key, import_id):
|
||||||
import_data_url = "https://{0}.{1}/api/v1/imports/{2}?api_key={3}".format(
|
import_data_url = "https://{0}.{1}/api/v1/imports/{2}?api_key={3}".format(
|
||||||
username, host, import_id, api_key
|
username, host, import_id, api_key
|
||||||
)
|
)
|
||||||
import_data_response = requests.get(import_data_url)
|
import_data_response = requests.get(import_data_url)
|
||||||
if import_data_response.status_code != 200:
|
if import_data_response.status_code != 200:
|
||||||
print "Error getting the table name from the import data: {0}".format(import_data_response.text)
|
print "Error getting the table name from the import data: {0}".format(
|
||||||
sys.exit(1)
|
import_data_response.text
|
||||||
import_data_json = json.loads(import_data_response.text)
|
)
|
||||||
return import_data_json['table_name']
|
sys.exit(1)
|
||||||
|
import_data_json = json.loads(import_data_response.text)
|
||||||
|
|
||||||
|
return import_data_json['table_name']
|
||||||
|
|
||||||
|
|
||||||
def execute_tests():
|
def execute_tests():
|
||||||
print "Start testing..."
|
print "Start testing..."
|
||||||
process = subprocess.Popen(["nosetests", "--where=integration/"])
|
process = subprocess.Popen(["nosetests", "--where=integration/"])
|
||||||
process.wait()
|
process.wait()
|
||||||
print "Testing finished!"
|
print "Testing finished!"
|
||||||
|
|
||||||
|
|
||||||
def set_environment_variables(username, api_key, table_name, host):
|
def set_environment_variables(username, api_key, table_name, host):
|
||||||
os.environ["GEOCODER_API_TEST_USERNAME"] = username
|
os.environ["GEOCODER_API_TEST_USERNAME"] = username
|
||||||
os.environ["GEOCODER_API_TEST_API_KEY"] = api_key
|
os.environ["GEOCODER_API_TEST_API_KEY"] = api_key
|
||||||
os.environ["GEOCODER_API_TEST_TABLE_NAME"] = table_name
|
os.environ["GEOCODER_API_TEST_TABLE_NAME"] = table_name
|
||||||
os.environ["GEOCODER_API_TEST_HOST"] = host
|
os.environ["GEOCODER_API_TEST_HOST"] = host
|
||||||
|
|
||||||
|
|
||||||
def clean_environment_variables():
|
def clean_environment_variables():
|
||||||
print "Cleaning test dataset environment variables..."
|
print "Cleaning test dataset environment variables..."
|
||||||
del os.environ["GEOCODER_API_TEST_USERNAME"]
|
del os.environ["GEOCODER_API_TEST_USERNAME"]
|
||||||
del os.environ["GEOCODER_API_TEST_API_KEY"]
|
del os.environ["GEOCODER_API_TEST_API_KEY"]
|
||||||
del os.environ["GEOCODER_API_TEST_TABLE_NAME"]
|
del os.environ["GEOCODER_API_TEST_TABLE_NAME"]
|
||||||
del os.environ["GEOCODER_API_TEST_HOST"]
|
del os.environ["GEOCODER_API_TEST_HOST"]
|
||||||
|
|
||||||
|
|
||||||
def clean_test_dataset(username, api_key, table_name, host):
|
def clean_test_dataset(username, api_key, table_name, host):
|
||||||
print "Cleaning test dataset {0}...".format(table_name)
|
print "Cleaning test dataset {0}...".format(table_name)
|
||||||
url = "https://{0}.{1}/api/v2/sql?q=drop table {2}&api_key={3}".format(username, host, table_name, api_key)
|
url = "https://{0}.{1}/api/v2/sql?q=drop table {2}&api_key={3}".format(
|
||||||
response = requests.get(url)
|
username, host, table_name, api_key
|
||||||
if response.status_code != 200:
|
)
|
||||||
print "Error cleaning the test dataset: {0}".format(response.text)
|
response = requests.get(url)
|
||||||
sys.exit(1)
|
if response.status_code != 200:
|
||||||
|
print "Error cleaning the test dataset: {0}".format(response.text)
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
main()
|
main()
|
||||||
|
Loading…
Reference in New Issue
Block a user