Сначала я запускаю тестовый вход в систему, который возвращает код состояния 400, а затем второй тест, который входит в систему с использованием реального вызова службы. Тесты ниже:
@Test
public void mock() throws IOException, InterruptedException {
MockWebServer server = new MockWebServer();
server.enqueue(new MockResponse().setResponseCode(400));
server.start();
NetworkServiceHelper.init(String.valueOf(server.url("/"))); // Change retrofit baseUrl to localhost
loginWithoutWaiting(username, password);
server.shutdown();
}
@Test
public void real() {
NetworkServiceHelper.init(NetworkServiceHelper.DEFAULT_URL); // Change retrofit baseUrl to a real url
loginWithoutWaiting(username, password);
}
Настоящую службу не вызывают. Сообщение об ошибке EditText говорит
Не удалось пройти аутентификацию: не удалось подключиться к localhost/127.0.0.1:50162.
Вот функция NetworkServiceHelper.init(), которая инициализирует экземпляр Retrofit:
public static synchronized void init(String serverUrl) {
// Override the GSON date format.
Gson gson = new GsonBuilder()
.setDateFormat("yyyy-MM-dd'T'HH:mm:ssZ")
.create();
// We want to make the network calls asynchronous, so use createWithScheduler()
RxJavaCallAdapterFactory rxAdapter = RxJavaCallAdapterFactory.createWithScheduler(Schedulers.io());
// Finally, build the Retrofit client.
retrofit = new Retrofit.Builder()
.baseUrl(serverUrl)
.addConverterFactory(GsonConverterFactory.create(gson))
.addCallAdapterFactory(rxAdapter)
.client(buildClient())
.build();
}