forked from googlemaps/google-maps-services-java
-
Notifications
You must be signed in to change notification settings - Fork 0
/
AuthenticatedTest.java
90 lines (77 loc) · 3.17 KB
/
AuthenticatedTest.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
* Copyright 2014 Google Inc. All rights reserved.
*
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this
* file except in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
* ANY KIND, either express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.google.maps;
import org.junit.Ignore;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import java.util.ArrayList;
import java.util.Collection;
/**
* Base class for tests requiring automated authentication.
*
* <p>Sub-classes need to implement a 1-arg constructor that takes a GeoApiContext that will be
* supplied with an appropriate API key or client ID and secret set. The {@code RunWith
* (Paramaterized.class)} annotation will then ensure that each test that inherits will be run for
* each context returned from {@link #contexts()}. That is, if an API_KEY and
* CLIENT_ID+CLIENT_SECRET are found, each test will be run twice and supplied a context with the
* appropriate authentication tokens set.
*/
@RunWith(Parameterized.class)
@Ignore
public class AuthenticatedTest {
protected AuthenticatedTest() {
}
public static Collection<Object[]> contexts(boolean supportsClientId) {
Collection<Object[]> contexts = new ArrayList<Object[]>();
// Travis can't run authorized tests from pull requests.
// http://docs.travis-ci.com/user/pull-requests/#Security-Restrictions-when-testing-Pull-Requests
if (System.getenv("TRAVIS_PULL_REQUEST") != null
&& !"false".equals(System.getenv("TRAVIS_PULL_REQUEST"))) {
return contexts;
}
String apiKey = System.getenv("API_KEY");
if (apiKey == null) {
apiKey = System.getProperty("api.key");
}
if (apiKey != null && !apiKey.equalsIgnoreCase("")) {
GeoApiContext context = new GeoApiContext()
.setApiKey(apiKey);
contexts.add(new Object[]{context});
}
if (supportsClientId) {
String clientId = System.getenv("CLIENT_ID");
String clientSecret = System.getenv("CLIENT_SECRET");
if (clientId == null && clientSecret == null) {
clientId = System.getProperty("client.id");
clientSecret = System.getProperty("client.secret");
}
if (!(clientId == null || clientId.equals("") || clientSecret == null || clientSecret.equals(""))) {
GeoApiContext context = new GeoApiContext()
.setEnterpriseCredentials(clientId, clientSecret);
contexts.add(new Object[]{context});
}
}
if (contexts.size() == 0) {
throw new IllegalArgumentException("No credentials found! Set the API_KEY or CLIENT_ID and "
+ "CLIENT_SECRET environment variables to run tests requiring authentication.");
}
return contexts;
}
@Parameters
public static Collection<Object[]> contexts() {
return contexts(true);
}
}