@Test( groups = {"wso2.am"}, description = "API Life cycle test case") public void testDAOTestCase() throws Exception { String APIName = "DAOTestAPI"; String APIContext = "DAOTestAPI"; String tags = "youtube, video, media"; String url = "http://gdata.youtube.com/feeds/api/standardfeeds"; String description = "This is test API create by API manager integration test"; String APIVersion = "1.0.0"; String apiContextAddedValue = APIContext + "/" + APIVersion; APIRequest apiRequest = new APIRequest(APIName, APIContext, new URL(url)); apiRequest.setTags(tags); apiRequest.setDescription(description); apiRequest.setVersion(APIVersion); apiRequest.setProvider(providerName); apiPublisher.addAPI(apiRequest); apiPublisher.deleteAPI(APIName, APIVersion, providerName); apiPublisher.addAPI(apiRequest); APIBean apiBean = APIMTestCaseUtils.getAPIBeanFromHttpResponse(apiPublisher.getAPI(APIName, providerName)); APILifeCycleStateRequest updateRequest = new APILifeCycleStateRequest(APIName, providerName, APILifeCycleState.PUBLISHED); apiPublisher.changeAPILifeCycleStatus(updateRequest); // Test API properties assertEquals(apiBean.getId().getApiName(), APIName, "API Name mismatch"); assertTrue(apiBean.getContext().contains(apiContextAddedValue), "API context mismatch"); assertEquals(apiBean.getId().getVersion(), APIVersion, "API version mismatch"); assertEquals(apiBean.getId().getProviderName(), providerName, "Provider Name mismatch"); for (String tag : apiBean.getTags()) { assertTrue(tags.contains(tag), "API tag data mismatched"); } assertEquals(apiBean.getDescription(), description, "API description mismatch"); apiStore.addApplication("DAOTestAPI-Application", "Gold", "", "this-is-test"); SubscriptionRequest subscriptionRequest = new SubscriptionRequest( APIName, storeContext.getContextTenant().getContextUser().getUserName()); subscriptionRequest.setApplicationName("DAOTestAPI-Application"); apiStore.subscribe(subscriptionRequest); APPKeyRequestGenerator generateAppKeyRequest = new APPKeyRequestGenerator("DAOTestAPI-Application"); String responseString = apiStore.generateApplicationKey(generateAppKeyRequest).getData(); JSONObject response = new JSONObject(responseString); String accessToken = response.getJSONObject("data").getJSONObject("key").get("accessToken").toString(); Map<String, String> requestHeaders = new HashMap<String, String>(); requestHeaders.put("Authorization", "Bearer " + accessToken); Thread.sleep(2000); }
@Test( groups = {"wso2.am"}, description = "Test changing of the API Tier from Gold to Silver", dependsOnMethods = "testInvokingAfterExpireThrottleExpireTime") public void testEditAPITierToSilver() throws APIManagerIntegrationTestException, MalformedURLException { apiCreationRequestBean = new APICreationRequestBean( API_NAME, API_CONTEXT, API_VERSION_1_0_0, providerName, new URL(apiEndPointUrl)); apiCreationRequestBean.setTags(API_TAGS); apiCreationRequestBean.setDescription(API_DESCRIPTION); apiCreationRequestBean.setTier(TIER_SILVER); apiCreationRequestBean.setTiersCollection(TIER_SILVER); // Update API with Edited information with Tier Silver HttpResponse updateAPIHTTPResponse = apiPublisherClientUser1.updateAPI(apiCreationRequestBean); assertEquals( updateAPIHTTPResponse.getResponseCode(), HTTP_RESPONSE_CODE_OK, "Update API Response Code is" + " invalid. Updating of API information fail" + getAPIIdentifierString(apiIdentifier)); assertEquals( getValueFromJSON(updateAPIHTTPResponse, "error"), "false", "Error in API Update in " + getAPIIdentifierString(apiIdentifier) + "Response Data:" + updateAPIHTTPResponse.getData()); }
@Test( groups = {"wso2.am"}, description = "Test changing of the API end point URL", dependsOnMethods = "testAPIInvocationBeforeChangeTheEndPointURL") public void testEditEndPointURL() throws APIManagerIntegrationTestException, MalformedURLException { // Create the API Request with new context APICreationRequestBean apiCreationRequestBeanUpdate = new APICreationRequestBean( API_NAME, API_CONTEXT, API_VERSION_1_0_0, providerName, new URL(API2_END_POINT_URL)); apiCreationRequestBeanUpdate.setTags(API_TAGS); apiCreationRequestBeanUpdate.setDescription(API_DESCRIPTION); // Update API with Edited information HttpResponse updateAPIHTTPResponse = apiPublisherClientUser1.updateAPI(apiCreationRequestBeanUpdate); assertEquals( updateAPIHTTPResponse.getResponseCode(), HTTP_RESPONSE_CODE_OK, "Update API end point URL Response Code is invalid." + getAPIIdentifierString(apiIdentifier)); assertEquals( getValueFromJSON(updateAPIHTTPResponse, "error"), "false", "Error in API end point URL Update in " + getAPIIdentifierString(apiIdentifier) + "Response Data:" + updateAPIHTTPResponse.getData()); }
@BeforeClass(alwaysRun = true) public void setEnvironment() throws Exception { super.init(userMode); apiPublisher = new APIPublisherRestClient(getPublisherURLHttp()); apiStore = new APIStoreRestClient(getStoreURLHttp()); providerName = user.getUserName(); apiPublisher.login(user.getUserName(), user.getPassword()); apiStore.login(user.getUserName(), user.getPassword()); }
@BeforeClass(alwaysRun = true) public void setEnvironment() throws Exception { super.init(); String publisherURLHttp = publisherUrls.getWebAppURLHttp(); String storeURLHttp = storeUrls.getWebAppURLHttp(); apiStore = new APIStoreRestClient(storeURLHttp); apiPublisher = new APIPublisherRestClient(publisherURLHttp); apiPublisher.login( publisherContext.getContextTenant().getContextUser().getUserName(), publisherContext.getContextTenant().getContextUser().getPassword()); apiStore.login( storeContext.getContextTenant().getContextUser().getUserName(), storeContext.getContextTenant().getContextUser().getPassword()); }
@BeforeClass(alwaysRun = true) public void initialize() throws APIManagerIntegrationTestException, XPathExpressionException { super.init(); apiEndPointUrl = gatewayUrls.getWebAppURLHttp() + API_END_POINT_POSTFIX_URL; providerName = publisherContext.getContextTenant().getContextUser().getUserName(); String publisherURLHttp = publisherUrls.getWebAppURLHttp(); String storeURLHttp = storeUrls.getWebAppURLHttp(); apiPublisherClientUser1 = new APIPublisherRestClient(publisherURLHttp); apiStoreClientUser1 = new APIStoreRestClient(storeURLHttp); // Login to API Publisher with admin apiPublisherClientUser1.login( publisherContext.getContextTenant().getContextUser().getUserName(), publisherContext.getContextTenant().getContextUser().getPassword()); // Login to API Store with admin apiStoreClientUser1.login( storeContext.getContextTenant().getContextUser().getUserName(), storeContext.getContextTenant().getContextUser().getPassword()); apiIdentifier = new APIIdentifier(providerName, API_NAME, API_VERSION_1_0_0); }
@Test( groups = {"wso2.am"}, description = "Test availability of tiers in API Manage Page before change tiers XML", dependsOnMethods = "testAvailabilityOfTiersInPermissionPageBeforeChangeTiersXML") public void testAvailabilityOfTiersInAPIManagePageBeforeChangeTiersXML() throws APIManagerIntegrationTestException { HttpResponse tierManagePageHttpResponse = apiPublisherClientUser1.getAPIManagePage(API_NAME, providerName, API_VERSION_1_0_0); assertEquals( tierManagePageHttpResponse.getResponseCode(), HTTP_RESPONSE_CODE_OK, "Response code mismatched when invoke to get Tier Permission Page"); assertTrue( tierManagePageHttpResponse.getData().contains(TIER_MANAGE_PAGE_TIER_GOLD), "default tier Gold is not available in Tier Permission page before add new tear in tiers.xml"); assertFalse( tierManagePageHttpResponse.getData().contains(TIER_MANAGE_PAGE_TIER_PLATINUM), "new tier Platinum available in Tier Permission page before add new tear in tiers.xml"); }
@Test( groups = {"wso2.am"}, description = "test availability of tiers in Permission Page before change tiers XML") public void testAvailabilityOfTiersInPermissionPageBeforeChangeTiersXML() throws APIManagerIntegrationTestException { // Create a API APIIdentifier apiIdentifier = new APIIdentifier(providerName, API_NAME, API_VERSION_1_0_0); createAndPublishAPI(apiIdentifier, apiCreationRequestBean, apiPublisherClientUser1, false); HttpResponse tierPermissionPageHttpResponse = apiPublisherClientUser1.getTierPermissionsPage(); assertEquals( tierPermissionPageHttpResponse.getResponseCode(), HTTP_RESPONSE_CODE_OK, "Response code mismatched when invoke to get Tier Permission Page"); assertTrue( tierPermissionPageHttpResponse.getData().contains(TIER_PERMISSION_PAGE_TIER_GOLD), "default tier Gold is not available in Tier Permission page before add new tear in tiers.xml"); assertFalse( tierPermissionPageHttpResponse.getData().contains(TIER_PERMISSION_PAGE_TIER_PLATINUM), "new tier Platinum available in Tier Permission page before add new tear in tiers.xml"); }
@BeforeClass(alwaysRun = true) public void initialize() throws APIManagerIntegrationTestException, XPathExpressionException, RemoteException, ResourceAdminServiceExceptionException, MalformedURLException { super.init(); apiEndPointUrl = getGatewayURLHttp() + API_END_POINT_POSTFIX_URL; providerName = user.getUserName(); apiCreationRequestBean = new APICreationRequestBean( API_NAME, API_CONTEXT, API_VERSION_1_0_0, providerName, new URL(apiEndPointUrl)); apiCreationRequestBean.setTags(API_TAGS); apiCreationRequestBean.setDescription(API_DESCRIPTION); String publisherURLHttp = getPublisherURLHttp(); String storeURLHttp = getStoreURLHttp(); apiPublisherClientUser1 = new APIPublisherRestClient(publisherURLHttp); APIStoreRestClient apiStoreClientUser1 = new APIStoreRestClient(storeURLHttp); // Login to API Publisher with admin apiPublisherClientUser1.login(user.getUserName(), user.getPassword()); // Login to API Store with admin apiStoreClientUser1.login(user.getUserName(), user.getPassword()); apiIdentifier = new APIIdentifier(providerName, API_NAME, API_VERSION_1_0_0); String artifactsLocation = TestConfigurationProvider.getResourceLocation() + File.separator + "artifacts" + File.separator + "AM" + File.separator + "lifecycletest" + File.separator + "tiers.xml"; resourceAdminServiceClient = new ResourceAdminServiceClient( publisherContext.getContextUrls().getBackEndUrl(), createSession(publisherContext)); originalTiersXML = resourceAdminServiceClient.getTextContent(TIER_XML_REG_CONFIG_LOCATION); newTiersXML = readFile(artifactsLocation); }
@Test( groups = {"wso2.am"}, description = "test availability of tiers in Permission Page after change tiers XML", dependsOnMethods = "testAvailabilityOfTiersInAPIManagePageBeforeChangeTiersXML") public void testAvailabilityOfTiersInPermissionPageAfterChangeTiersXML() throws RemoteException, ResourceAdminServiceExceptionException, APIManagerIntegrationTestException { // Changing the Tier XML resourceAdminServiceClient.updateTextContent(TIER_XML_REG_CONFIG_LOCATION, newTiersXML); HttpResponse tierPermissionPageHttpResponse = apiPublisherClientUser1.getTierPermissionsPage(); assertEquals( tierPermissionPageHttpResponse.getResponseCode(), HTTP_RESPONSE_CODE_OK, "Response code mismatched when invoke to get Tier Permission Page"); assertTrue( tierPermissionPageHttpResponse.getData().contains(TIER_PERMISSION_PAGE_TIER_GOLD), "default tier Gold is not available in Tier Permission page before add new tear in tiers.xml"); assertTrue( tierPermissionPageHttpResponse.getData().contains(TIER_PERMISSION_PAGE_TIER_PLATINUM), "new tier Platinum is not available in Tier Permission page before add new tear in tiers.xml"); }
@BeforeClass(alwaysRun = true) public void initialize() throws APIManagerIntegrationTestException, XPathExpressionException, MalformedURLException { super.init(); api1EndPointUrl = getGatewayURLHttp() + API_END_POINT_POSTFIX_URL; providerName = user.getUserName(); apiCreationRequestBean = new APICreationRequestBean( API_NAME, API_CONTEXT, API_VERSION_1_0_0, providerName, new URL(api1EndPointUrl)); apiCreationRequestBean.setTags(API_TAGS); apiCreationRequestBean.setDescription(API_DESCRIPTION); String publisherURLHttp = getPublisherURLHttp(); String storeURLHttp = getStoreURLHttp(); apiPublisherClientUser1 = new APIPublisherRestClient(publisherURLHttp); apiStoreClientUser1 = new APIStoreRestClient(storeURLHttp); // Login to API Publisher with admin apiPublisherClientUser1.login(user.getUserName(), user.getPassword()); // Login to API Store with admin apiStoreClientUser1.login(user.getUserName(), user.getPassword()); apiIdentifier = new APIIdentifier(providerName, API_NAME, API_VERSION_1_0_0); apiStoreClientUser1.addApplication(APPLICATION_NAME, TIER_UNLIMITED, "", ""); }
@BeforeClass(alwaysRun = true) public void initialize() throws APIManagerIntegrationTestException, XPathExpressionException, RemoteException { super.init(); apiEndPointUrl = getGatewayURLHttp() + API_END_POINT_POSTFIX_URL; providerName = user.getUserName(); String publisherURLHttp = getPublisherURLHttp(); String storeURLHttp = getStoreURLHttp(); apiPublisherClientUser1 = new APIPublisherRestClient(publisherURLHttp); apiStoreClientUser1 = new APIStoreRestClient(storeURLHttp); // Login to API Publisher with admin apiPublisherClientUser1.login(user.getUserName(), user.getPassword()); // Login to API Store with admin apiStoreClientUser1.login(user.getUserName(), user.getPassword()); requestHeadersGet = new HashMap<String, String>(); requestHeadersGet.put("accept", "text/plain"); requestHeadersGet.put("Content-Type", "text/plain"); apiIdentifier = new APIIdentifier(providerName, API_NAME, API_VERSION_1_0_0); // Create application apiStoreClientUser1.addApplication( APPLICATION_NAME, APIMIntegrationConstants.APPLICATION_TIER.UNLIMITED, "", ""); }
@Test( groups = {"wso2.am"}, dataProvider = "SymbolCharacters", description = "Test the API with endpoint security" + " enabled with complex password", dependsOnMethods = "testInvokeGETResourceWithSecuredEndPointPasswordOnlyNumbersAndLetters") public void testInvokeGETResourceWithSecuredEndPointComplexPassword(String symbolicCharacter) throws Exception { String endpointUsername = "******"; char[] endpointPassword = { 'a', 'b', 'c', 'd', symbolicCharacter.charAt(0), 'e', 'f', 'g', 'h', 'i', 'j', 'k' }; byte[] userNamePasswordByteArray = (endpointUsername + ":" + String.valueOf(endpointPassword)).getBytes(); String encodedUserNamePassword = DatatypeConverter.printBase64Binary(userNamePasswordByteArray); APICreationRequestBean apiCreationRequestBean = new APICreationRequestBean( API_NAME, API_CONTEXT, API_VERSION_1_0_0, providerName, new URL(apiEndPointUrl)); apiCreationRequestBean.setTags(API_TAGS); apiCreationRequestBean.setDescription(API_DESCRIPTION); apiCreationRequestBean.setVisibility("public"); apiCreationRequestBean.setEndpointType("secured"); apiCreationRequestBean.setEpUsername(endpointUsername); apiCreationRequestBean.setEpPassword( URLEncoder.encode(String.valueOf(endpointPassword), "UTF-8")); // Update API with Edited information HttpResponse updateAPIHTTPResponse = apiPublisherClientUser1.updateAPI(apiCreationRequestBean); assertEquals( updateAPIHTTPResponse.getResponseCode(), HTTP_RESPONSE_CODE_OK, "Update APi with new Resource " + "information fail"); assertEquals( updateAPIHTTPResponse.getData(), "{\"error\" : false}", "Update APi with new Resource information fail"); // Send GET request waitForAPIDeploymentSync( user.getUserName(), API_NAME, API_VERSION_1_0_0, encodedUserNamePassword); HttpResponse httpResponseGet = HttpRequestUtil.doGet( getAPIInvocationURLHttp(API_CONTEXT, API_VERSION_1_0_0) + "/sec", requestHeadersGet); assertEquals( httpResponseGet.getResponseCode(), HTTP_RESPONSE_CODE_OK, "Invocation fails for GET request for " + "endpoint type secured. username:"******" password:"******"Response Data not match for GET" + " request for endpoint type secured. Expected value : " + encodedUserNamePassword + " not contains in " + "response data: " + httpResponseGet.getData() + " username:"******" password:" + String.valueOf(endpointPassword)); }
@Test( groups = {"wso2.am"}, description = "Pizzashack Test") public void testPizzashackApiSample() throws Exception { List<APIResourceBean> resourceBeanList = new ArrayList<APIResourceBean>(); APICreationRequestBean apiCreationRequestBean = new APICreationRequestBean( "PizzaAPI", "pizzashack", "1.0.0", "admin", new URL("http://localhost:9766/pizzashack-api-1.0.0/api/")); apiCreationRequestBean.setThumbUrl("/home/bhagya/WS/Pizza_Shack_Logo.jpeg"); apiCreationRequestBean.setDescription( "Pizza API:Allows to manage pizza orders (create, update, retrieve orders)"); apiCreationRequestBean.setTags("pizza, order, pizza-menu"); apiCreationRequestBean.setResourceCount("4"); resourceBeanList.add( new APIResourceBean("GET", "Application & Application User", "Unlimited", "/menu")); resourceBeanList.add( new APIResourceBean("POST", "Application & Application User", "Unlimited", "/order")); resourceBeanList.add( new APIResourceBean( "GET", "Application & Application User", "Unlimited", "/order/{orderid}")); resourceBeanList.add( new APIResourceBean("GET", "Application & Application User", "Unlimited", "/delivery")); apiCreationRequestBean.setResourceBeanList(resourceBeanList); apiCreationRequestBean.setTier("Unlimited"); apiCreationRequestBean.setTiersCollection("Unlimited"); apiPublisher.addAPI(apiCreationRequestBean); APILifeCycleStateRequest updateRequest = new APILifeCycleStateRequest( "PizzaAPI", publisherContext.getContextTenant().getContextUser().getUserName(), APILifeCycleState.PUBLISHED); apiPublisher.changeAPILifeCycleStatus(updateRequest); apiStore.addApplication("PizzaShack", "Unlimited", "", ""); SubscriptionRequest subscriptionRequest = new SubscriptionRequest( "PizzaAPI", storeContext.getContextTenant().getContextUser().getUserName()); subscriptionRequest.setApplicationName("PizzaShack"); apiStore.subscribe(subscriptionRequest); APPKeyRequestGenerator generateAppKeyRequest = new APPKeyRequestGenerator("PizzaShack"); String responseString = apiStore.generateApplicationKey(generateAppKeyRequest).getData(); JSONObject response = new JSONObject(responseString); String accessToken = response.getJSONObject("data").getJSONObject("key").get("accessToken").toString(); Map<String, String> requestHeaders = new HashMap<String, String>(); requestHeaders.put("Authorization", "Bearer " + accessToken); Thread.sleep(2000); HttpResponse pizzaShackResponse = HttpRequestUtil.doGet( gatewayUrlsMgt.getWebAppURLNhttp() + "pizzashack/1.0.0/menu", requestHeaders); assertEquals( pizzaShackResponse.getResponseCode(), Response.Status.OK.getStatusCode(), "Response code mismatched when api invocation"); System.out.println("My Response Code is " + pizzaShackResponse.getResponseCode()); assertTrue( pizzaShackResponse.getData().contains("BBQ Chicken Bacon"), "Response data mismatched when api invocation"); assertTrue( pizzaShackResponse.getData().contains("Grilled white chicken"), "Response data mismatched when api invocation"); assertTrue( pizzaShackResponse.getData().contains("Chicken Parmesan"), "Response data mismatched when api invocation"); assertTrue( pizzaShackResponse.getData().contains("Tuscan Six Cheese"), "Response data mismatched when api invocation"); assertTrue( pizzaShackResponse.getData().contains("Asiago and Fontina"), "Response data mismatched when api invocation"); }
@BeforeClass(alwaysRun = true) public void setEnvironment() throws Exception { super.init(userMode); // Load the back-end dummy API if (TestUserMode.SUPER_TENANT_ADMIN == userMode) { String gatewaySessionCookie = createSession(gatewayContextMgt); loadSynapseConfigurationFromClasspath( "artifacts" + File.separator + "AM" + File.separator + "synapseconfigs" + File.separator + "rest" + File.separator + "dummy_api.xml", gatewayContextMgt, gatewaySessionCookie); } publisherURLHttp = getPublisherURLHttp(); apiPublisher = new APIPublisherRestClient(publisherURLHttp); apiPublisher.login(user.getUserName(), user.getPassword()); String providerName = user.getUserName(); URL endpointUrl = new URL(getSuperTenantAPIInvocationURLHttp("response", "1.0.0")); ArrayList<APIResourceBean> resourceBeanList = new ArrayList<APIResourceBean>(); resourceBeanList.add( new APIResourceBean( APIMIntegrationConstants.HTTP_VERB_GET, APIMIntegrationConstants.RESOURCE_AUTH_TYPE_APPLICATION_AND_APPLICATION_USER, APIMIntegrationConstants.RESOURCE_TIER.UNLIMITED, "/*")); apiCreationRequestBean = new APICreationRequestBean( API_NAME, API_CONTEXT, API_VERSION, providerName, endpointUrl, resourceBeanList); apiCreationRequestBean.setTags(TAGS); apiCreationRequestBean.setDescription(DESCRIPTION); String publisherURLHttp = getPublisherURLHttp(); String storeURLHttp = getStoreURLHttp(); apiPublisherClientUser1 = new APIPublisherRestClient(publisherURLHttp); apiStoreClientUser1 = new APIStoreRestClient(storeURLHttp); // Login to API Publisher with admin apiPublisherClientUser1.login(user.getUserName(), user.getPassword()); // Login to API Store with admin apiStoreClientUser1.login(user.getUserName(), user.getPassword()); apiIdentifier = new APIIdentifier(providerName, API_NAME, API_VERSION); apiIdentifier.setTier(APIMIntegrationConstants.API_TIER.GOLD); // Create application apiStoreClientUser1.addApplication( APPLICATION_NAME, APIMIntegrationConstants.APPLICATION_TIER.LARGE, "", ""); accessToken = generateApplicationKeys(apiStoreClientUser1, APPLICATION_NAME).getAccessToken(); createPublishAndSubscribeToAPI( apiIdentifier, apiCreationRequestBean, apiPublisherClientUser1, apiStoreClientUser1, APPLICATION_NAME); waitForAPIDeploymentSync( user.getUserName(), API_NAME, API_VERSION, APIMIntegrationConstants.IS_API_EXISTS); }
@BeforeClass(alwaysRun = true) public void setEnvironment() throws Exception { super.init(userMode); String publisherURLHttp = publisherUrls.getWebAppURLHttp(); String storeURLHttp = storeUrls.getWebAppURLHttp(); apiStore = new APIStoreRestClient(storeURLHttp); APIPublisherRestClient apiPublisher = new APIPublisherRestClient(publisherURLHttp); String APIName = "APIGetAllSubscriptionsTestAPI"; String APIContext = "getAllSubscriptionsTestAPI"; String tags = "youtube, video, media"; String url = "http://gdata.youtube.com/feeds/api/standardfeeds"; String description = "This is test API create by API manager integration test"; String providerName = "admin"; String APIVersion = "1.0.0"; apiPublisher.login( publisherContext.getContextTenant().getContextUser().getUserName(), publisherContext.getContextTenant().getContextUser().getPassword()); APIRequest apiRequest = new APIRequest(APIName, APIContext, new URL(url)); apiRequest.setTags(tags); apiRequest.setDescription(description); apiRequest.setVersion(APIVersion); apiRequest.setVisibility("restricted"); apiRequest.setRoles("admin"); apiRequest.setTiersCollection(SILVER); apiRequest.setTier(SILVER); apiPublisher.addAPI(apiRequest); APILifeCycleStateRequest updateRequest = new APILifeCycleStateRequest(APIName, providerName, APILifeCycleState.PUBLISHED); apiPublisher.changeAPILifeCycleStatus(updateRequest); apiStore.login( storeContext.getContextTenant().getContextUser().getUserName(), storeContext.getContextTenant().getContextUser().getPassword()); for (int i = 0; i < numberOfApplications; i++) { String applicationName = applicationNamePrefix + i; apiStore.addApplication( applicationName, APIMIntegrationConstants.APPLICATION_TIER.DEFAULT_APP_POLICY_FIFTY_REQ_PER_MIN, "", "this-is-test"); SubscriptionRequest subscriptionRequest = new SubscriptionRequest( APIName, storeContext.getContextTenant().getContextUser().getUserName()); subscriptionRequest.setApplicationName(applicationName); subscriptionRequest.setTier(SILVER); apiStore.subscribe(subscriptionRequest); APPKeyRequestGenerator generateAppKeyRequest = new APPKeyRequestGenerator(applicationName); String responseString = apiStore.generateApplicationKey(generateAppKeyRequest).getData(); JSONObject response = new JSONObject(responseString); String error = response.getString("error"); if ("true".equals(error)) { throw new Exception("Unable to generate the tokens. Hence unable to execute the test case"); } } Thread.sleep(60000); }
@Test(groups = "wso2.am", description = "Check functionality of the default version API") public void testDefaultVersionAPI() throws Exception { // Login to the API Publisher apiPublisher.login(user.getUserName(), user.getPassword()); String apiName = "DefaultVersionAPI"; String apiVersion = "1.0.0"; String apiContext = "defaultversion"; String endpointUrl = getGatewayURLNhttp() + "response"; // Create the api creation request object APIRequest apiRequest = new APIRequest(apiName, apiContext, new URL(endpointUrl)); apiRequest.setDefault_version("default_version"); apiRequest.setDefault_version_checked("default_version"); apiRequest.setVersion(apiVersion); apiRequest.setTiersCollection("Unlimited"); apiRequest.setTier("Unlimited"); apiRequest.setProvider(provider); // Add the API using the API publisher. HttpResponse response = apiPublisher.addAPI(apiRequest); APILifeCycleStateRequest updateRequest = new APILifeCycleStateRequest(apiName, user.getUserName(), APILifeCycleState.PUBLISHED); // Publish the API response = apiPublisher.changeAPILifeCycleStatus(updateRequest); // Login to the API Store apiStore.login(user.getUserName(), user.getPassword()); // Add an Application in the Store. response = apiStore.addApplication("DefaultVersionAPP", "Unlimited", "", ""); verifyResponse(response); // Subscribe the API to the DefaultApplication SubscriptionRequest subscriptionRequest = new SubscriptionRequest(apiName, apiVersion, provider, "DefaultVersionAPP", "Unlimited"); response = apiStore.subscribe(subscriptionRequest); // Generate production token and invoke with that APPKeyRequestGenerator generateAppKeyRequest = new APPKeyRequestGenerator("DefaultVersionAPP"); String responseString = apiStore.generateApplicationKey(generateAppKeyRequest).getData(); JSONObject jsonResponse = new JSONObject(responseString); // Get the accessToken which was generated. String accessToken = jsonResponse.getJSONObject("data").getJSONObject("key").getString("accessToken"); String apiInvocationUrl = getAPIInvocationURLHttp(apiContext); // Going to access the API without the version in the request url. HttpResponse directResponse = HttpRequestUtil.doGet(endpointUrl, new HashMap<String, String>()); Map<String, String> headers = new HashMap<String, String>(); headers.put("Authorization", "Bearer " + accessToken); // Invoke the API HttpResponse httpResponse = HttpRequestUtil.doGet(apiInvocationUrl, headers); // Check if accessing the back-end directly and accessing it via the API yield the same // responses. assertEquals( httpResponse.getData(), directResponse.getData(), "Default version API test failed while " + "invoking the API."); }