-- Make sure dbs are clean DELETE FROM global_postal_code_points; DELETE FROM global_postal_code_polygons; DELETE FROM country_decoder; DELETE FROM available_services; DELETE FROM admin0_synonyms; -- Check that the public function is callable, even with no data -- It should return NULL SELECT cdb_geocoder_server.cdb_geocode_postalcode_point('test_user', 'test_org', '03204'); cdb_geocode_postalcode_point ------------------------------ (1 row) -- Insert dummy data into ip_address_locations INSERT INTO global_postal_code_points (the_geom, iso3, postal_code, postal_code_num) VALUES ( '0101000020E61000000000000000E040408036B47414764840', 'ESP', '03204', 3204 ); INSERT INTO global_postal_code_polygons (the_geom, iso3, postal_code, postal_code_num) VALUES ( '0106000020E610000001000000010300000001000000040000000000000000E000C01F383D7839B740400000000000E000C0AA3C0EDE220F3B4000000000004812404FB7FCCD04893D400000000000E000C01F383D7839B74040', 'ESP', '03204', 3204 ); INSERT INTO country_decoder (iso3, synonyms) VALUES ( 'ESP', Array['spain', 'Spain', 'ESP'] ); INSERT INTO available_services (adm0_a3, admin0, postal_code_points, postal_code_polygons) VALUES ( 'ESP', 't', 't', 't' ); INSERT INTO admin0_synonyms (adm0_a3, name, name_, rank) VALUES ( 'ESP', 'Spain', 'spain', 3 ); -- This should return the polygon inserted above SELECT cdb_geocoder_server.cdb_geocode_postalcode_point('test_user', 'test_org', '03204'); cdb_geocode_postalcode_point ---------------------------------------------------- 0101000020E61000000000000000E040408036B47414764840 (1 row) SELECT cdb_geocoder_server.cdb_geocode_postalcode_point('test_user', 'test_org', '03204', 'spain'); cdb_geocode_postalcode_point ---------------------------------------------------- 0101000020E61000000000000000E040408036B47414764840 (1 row) SELECT cdb_geocoder_server.cdb_geocode_postalcode_polygon('test_user', 'test_org', '03204'); cdb_geocode_postalcode_polygon -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 0106000020E610000001000000010300000001000000040000000000000000E000C01F383D7839B740400000000000E000C0AA3C0EDE220F3B4000000000004812404FB7FCCD04893D400000000000E000C01F383D7839B74040 (1 row) SELECT cdb_geocoder_server.cdb_geocode_postalcode_polygon('test_user', 'test_org', '03204', 'spain'); cdb_geocode_postalcode_polygon -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 0106000020E610000001000000010300000001000000040000000000000000E000C01F383D7839B740400000000000E000C0AA3C0EDE220F3B4000000000004812404FB7FCCD04893D400000000000E000C01F383D7839B74040 (1 row) -- Clean dbs DELETE FROM global_postal_code_points; DELETE FROM global_postal_code_polygons; DELETE FROM country_decoder; DELETE FROM available_services; DELETE FROM admin0_synonyms; -- Check for namedplaces signatures (point and polygon) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = 'cdb_geocode_postalcode_point' AND oidvectortypes(p.proargtypes) = 'text, text, text'); exists -------- t (1 row) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = 'cdb_geocode_postalcode_point' AND oidvectortypes(p.proargtypes) = 'text, text, text, text'); exists -------- t (1 row) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = 'cdb_geocode_postalcode_polygon' AND oidvectortypes(p.proargtypes) = 'text, text, text'); exists -------- t (1 row) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = 'cdb_geocode_postalcode_polygon' AND oidvectortypes(p.proargtypes) = 'text, text, text, text'); exists -------- t (1 row) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = '_cdb_geocode_postalcode_point' AND oidvectortypes(p.proargtypes) = 'text'); exists -------- t (1 row) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = '_cdb_geocode_postalcode_point' AND oidvectortypes(p.proargtypes) = 'text, text'); exists -------- t (1 row) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = '_cdb_geocode_postalcode_polygon' AND oidvectortypes(p.proargtypes) = 'text'); exists -------- t (1 row) SELECT exists(SELECT * FROM pg_proc p INNER JOIN pg_namespace ns ON (p.pronamespace = ns.oid) WHERE ns.nspname = 'cdb_geocoder_server' AND proname = '_cdb_geocode_postalcode_polygon' AND oidvectortypes(p.proargtypes) = 'text, text'); exists -------- t (1 row)