use of com.google.api.ads.common.lib.auth.OfflineCredentials in project googleads-java-lib by googleads.
the class AdWordsAxisSoapIntegrationTest method testGoldenSoap_oauth2_offlineCredentials.
@Test
public void testGoldenSoap_oauth2_offlineCredentials() throws Exception {
testHttpServer.setMockResponseBodies(Lists.newArrayList(AuthResponseProvider.getTestOAuthResponse("TEST_ACCESS_TOKEN_1", 1L, "newRefreshToken1"), AuthResponseProvider.getTestOAuthResponse("TEST_ACCESS_TOKEN_2", 3600L, "newRefreshToken2"), SoapResponseXmlProvider.getTestSoapResponse(API_VERSION)));
OfflineCredentials offlineCredentials = new OfflineCredentials.Builder().forApi(OfflineCredentials.Api.ADWORDS).withTokenUrlServer(testHttpServer.getServerUrl()).fromFile(AdWordsAxisSoapIntegrationTest.class.getResource("props/ads-test.properties")).build();
Credential credential = offlineCredentials.generateCredential();
assertTrue(testHttpServer.getLastRequestBody().contains("grant_type=refresh_token"));
assertTrue(testHttpServer.getLastRequestBody().contains("refresh_token=refreshToken"));
assertTrue(testHttpServer.getLastRequestBody().contains("client_id=clientId"));
assertTrue(testHttpServer.getLastRequestBody().contains("client_secret=clientSecret"));
// Make sure the old token expires - the session builder should issue a request
// for another access token.
Thread.sleep(1000);
assertEquals("TEST_ACCESS_TOKEN_1", credential.getAccessToken());
AdWordsSession session = new AdWordsSession.Builder().withUserAgent("TEST_APP").withOAuth2Credential(credential).withEndpoint(testHttpServer.getServerUrl()).withDeveloperToken("TEST_DEVELOPER_TOKEN").withClientCustomerId("TEST_CLIENT_CUSTOMER_ID").build();
testBudgetServiceMutateRequest(session);
assertEquals("Bearer TEST_ACCESS_TOKEN_2", testHttpServer.getLastAuthorizationHttpHeader());
}
use of com.google.api.ads.common.lib.auth.OfflineCredentials in project googleads-java-lib by googleads.
the class AdManagerAxisSoapIntegrationTest method testGoldenSoap_oauth2_offlineCredentials.
/**
* Tests making a Axis Ad Manager API call with OfflineCredentials.
*/
@Test
public void testGoldenSoap_oauth2_offlineCredentials() throws Exception {
testHttpServer.setMockResponseBodies(Lists.newArrayList(AuthResponseProvider.getTestOAuthResponse("TEST_ACCESS_TOKEN_1", 1L, "newRefreshToken1"), AuthResponseProvider.getTestOAuthResponse("TEST_ACCESS_TOKEN_2", 3600L, "newRefreshToken2"), SoapResponseXmlProvider.getTestSoapResponse(API_VERSION)));
OfflineCredentials offlineCredentials = new OfflineCredentials.Builder().forApi(OfflineCredentials.Api.AD_MANAGER).withTokenUrlServer(testHttpServer.getServerUrl()).fromFile(AdManagerAxisSoapIntegrationTest.class.getResource("props/ads-test.properties")).build();
Credential credential = offlineCredentials.generateCredential();
assertTrue(testHttpServer.getLastRequestBody().contains("grant_type=refresh_token"));
assertTrue(testHttpServer.getLastRequestBody().contains("refresh_token=refreshToken"));
assertTrue(testHttpServer.getLastRequestBody().contains("client_id=clientId"));
assertTrue(testHttpServer.getLastRequestBody().contains("client_secret=clientSecret"));
// Make sure the old token expires - the session builder should issue a request
// for another access token.
Thread.sleep(1000);
assertEquals("TEST_ACCESS_TOKEN_1", credential.getAccessToken());
AdManagerSession session = new AdManagerSession.Builder().withApplicationName("TEST_APP").withOAuth2Credential(credential).withEndpoint(testHttpServer.getServerUrl()).withNetworkCode("TEST_NETWORK_CODE").build();
CompanyServiceInterface companyService = new AdManagerServices().get(session, CompanyServiceInterface.class);
Company[] companies = companyService.createCompanies(new Company[] { new Company() });
assertEquals(1234L, companies[0].getId().longValue());
Diff diff = DiffBuilder.compare(SoapRequestXmlProvider.getOAuth2SoapRequest(API_VERSION)).withTest(testHttpServer.getLastRequestBody()).checkForSimilar().build();
assertFalse(diff.hasDifferences());
assertFalse("Did not request compression but request was compressed", testHttpServer.wasLastRequestBodyCompressed());
assertEquals("newRefreshToken2", credential.getRefreshToken());
assertEquals("Bearer TEST_ACCESS_TOKEN_2", testHttpServer.getLastAuthorizationHttpHeader());
}
Aggregations