aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@sonarsource.com>2017-07-06 09:25:30 +0200
committerSimon Brandhof <simon.brandhof@sonarsource.com>2017-07-07 11:36:41 +0200
commite42d1ebefc43e016fa417938e17e5d1c633f5608 (patch)
treecb748c77bd9ced3ecc20a35d2e3760c78aa300d1
parent539c34e510ed4998d8dc0e6a4958d5fc49ffcc84 (diff)
downloadsonarqube-e42d1ebefc43e016fa417938e17e5d1c633f5608.tar.gz
sonarqube-e42d1ebefc43e016fa417938e17e5d1c633f5608.zip
SONAR-9520 fix Tomcat error "Unexpected state: headers already parsed"
-rw-r--r--pom.xml13
-rw-r--r--server/sonar-server/pom.xml4
-rw-r--r--tests/src/test/java/org/sonarqube/tests/serverSystem/ServerSystemTest.java43
-rw-r--r--tests/src/test/resources/serverSystem/ServerSystemTest/url_ending_by_jsp.html2
4 files changed, 23 insertions, 39 deletions
diff --git a/pom.xml b/pom.xml
index 36be56adfa3..254439d45da 100644
--- a/pom.xml
+++ b/pom.xml
@@ -67,7 +67,7 @@
<jetty.version>8.1.12.v20130726</jetty.version>
<logback.version>1.1.7</logback.version>
<slf4j.version>1.7.21</slf4j.version>
- <tomcat.version>8.5.11</tomcat.version>
+ <tomcat.version>8.5.16</tomcat.version>
<elasticsearch.version>2.4.4</elasticsearch.version>
<orchestrator.version>3.15.0.1090</orchestrator.version>
<okhttp.version>3.7.0</okhttp.version>
@@ -1050,14 +1050,13 @@
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-core</artifactId>
<version>${tomcat.version}</version>
- </dependency>
- <dependency>
- <groupId>org.apache.tomcat.embed</groupId>
- <artifactId>tomcat-embed-jasper</artifactId>
- <version>${tomcat.version}</version>
<exclusions>
<exclusion>
- <groupId>org.eclipse.jdt.core.compiler</groupId>
+ <groupId>org.apache.tomcat.embed</groupId>
+ <artifactId>tomcat-embed-jasper</artifactId>
+ </exclusion>
+ <exclusion>
+ <groupId>org.eclipse.jdt</groupId>
<artifactId>ecj</artifactId>
</exclusion>
</exclusions>
diff --git a/server/sonar-server/pom.xml b/server/sonar-server/pom.xml
index 41d96fa8534..89053a27fcb 100644
--- a/server/sonar-server/pom.xml
+++ b/server/sonar-server/pom.xml
@@ -44,10 +44,6 @@
<artifactId>tomcat-embed-core</artifactId>
</dependency>
<dependency>
- <groupId>org.apache.tomcat.embed</groupId>
- <artifactId>tomcat-embed-jasper</artifactId>
- </dependency>
- <dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
</dependency>
diff --git a/tests/src/test/java/org/sonarqube/tests/serverSystem/ServerSystemTest.java b/tests/src/test/java/org/sonarqube/tests/serverSystem/ServerSystemTest.java
index ad4adf46519..ed7784b3db9 100644
--- a/tests/src/test/java/org/sonarqube/tests/serverSystem/ServerSystemTest.java
+++ b/tests/src/test/java/org/sonarqube/tests/serverSystem/ServerSystemTest.java
@@ -21,7 +21,6 @@ package org.sonarqube.tests.serverSystem;
import com.sonar.orchestrator.Orchestrator;
import com.sonar.orchestrator.build.SonarScanner;
-import org.sonarqube.tests.Category4Suite;
import java.io.File;
import java.io.IOException;
import java.util.Map;
@@ -29,28 +28,24 @@ import okhttp3.Response;
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.IOUtils;
import org.json.simple.JSONValue;
-import org.junit.After;
import org.junit.Before;
import org.junit.ClassRule;
import org.junit.Rule;
import org.junit.Test;
+import org.sonarqube.pageobjects.Navigation;
+import org.sonarqube.pageobjects.ServerIdPage;
+import org.sonarqube.tests.Category4Suite;
+import org.sonarqube.tests.Tester;
import org.sonarqube.ws.MediaTypes;
import org.sonarqube.ws.ServerId.ShowWsResponse;
import org.sonarqube.ws.client.GetRequest;
-import org.sonarqube.ws.client.WsClient;
import org.sonarqube.ws.client.WsResponse;
-import org.sonarqube.pageobjects.Navigation;
-import org.sonarqube.pageobjects.ServerIdPage;
import util.ItUtils;
-import util.user.UserRule;
import static org.apache.commons.lang.StringUtils.startsWithAny;
import static org.assertj.core.api.Assertions.assertThat;
import static org.junit.Assert.fail;
import static util.ItUtils.call;
-import static util.ItUtils.newAdminWsClient;
-import static util.ItUtils.newWsClient;
-import static util.selenium.Selenese.runSelenese;
public class ServerSystemTest {
@@ -60,16 +55,11 @@ public class ServerSystemTest {
public static final Orchestrator orchestrator = Category4Suite.ORCHESTRATOR;
@Rule
- public UserRule userRule = UserRule.from(orchestrator);
+ public Tester tester = new Tester(orchestrator).disableOrganizations();
@Before
public void initAdminUser() {
- userRule.createAdminUser(ADMIN_USER_LOGIN, ADMIN_USER_LOGIN);
- }
-
- @After
- public void deleteAdminUser() {
- userRule.resetUsers();
+ tester.users().generateAdministrator(u -> u.setLogin(ADMIN_USER_LOGIN).setPassword(ADMIN_USER_LOGIN));
}
@Test
@@ -90,7 +80,7 @@ public class ServerSystemTest {
@Test
public void generate_server_id() throws IOException {
- Navigation nav = Navigation.create(orchestrator).openHome().logIn().submitCredentials(ADMIN_USER_LOGIN);
+ Navigation nav = tester.openBrowser().openHome().logIn().submitCredentials(ADMIN_USER_LOGIN);
String validIpAddress = getValidIpAddress();
nav.openServerId()
@@ -115,20 +105,20 @@ public class ServerSystemTest {
}
private Map<String, Object> callStatus() {
- WsResponse statusResponse = newWsClient(orchestrator).wsConnector().call(new GetRequest("api/system/status"));
+ WsResponse statusResponse = tester.wsClient().wsConnector().call(new GetRequest("api/system/status"));
return ItUtils.jsonToMap(statusResponse.content());
}
@Test
public void display_system_info() {
- runSelenese(orchestrator, "/serverSystem/ServerSystemTest/system_info.html");
+ tester.runHtmlTests("/serverSystem/ServerSystemTest/system_info.html");
}
@Test
public void download_system_info() throws Exception {
waitForComputeEngineToBeUp(orchestrator);
- WsResponse response = newAdminWsClient(orchestrator).wsConnector().call(
+ WsResponse response = tester.wsClient().wsConnector().call(
new GetRequest("api/system/info"));
assertThat(response.code()).isEqualTo(200);
@@ -162,8 +152,9 @@ public class ServerSystemTest {
*/
@Test
public void display_warnings_when_using_h2() {
- if (orchestrator.getConfiguration().getString("sonar.jdbc.dialect").equals("h2")) {
- runSelenese(orchestrator, "/serverSystem/ServerSystemTest/derby-warning.html");
+ String dialect = orchestrator.getConfiguration().getString("sonar.jdbc.dialect");
+ if (dialect == null || dialect.equals("h2") || dialect.equals("embedded")) {
+ tester.runHtmlTests("/serverSystem/ServerSystemTest/derby-warning.html");
}
}
@@ -172,7 +163,7 @@ public class ServerSystemTest {
*/
@Test
public void hide_jdbc_settings_to_non_admin() {
- runSelenese(orchestrator, "/serverSystem/ServerSystemTest/hide-jdbc-settings.html");
+ tester.runHtmlTests( "/serverSystem/ServerSystemTest/hide-jdbc-settings.html");
}
@Test
@@ -190,13 +181,12 @@ public class ServerSystemTest {
/**
* SONAR-3962
*/
- // TODO should be moved elsewhere
@Test
public void not_fail_with_url_ending_by_jsp() {
orchestrator.executeBuild(SonarScanner.create(ItUtils.projectDir("shared/xoo-sample"))
.setProperty("sonar.projectKey", "myproject.jsp"));
// Access dashboard
- runSelenese(orchestrator, "/serverSystem/ServerSystemTest/url_ending_by_jsp.html");
+ tester.runHtmlTests("/serverSystem/ServerSystemTest/url_ending_by_jsp.html");
}
/**
@@ -213,8 +203,7 @@ public class ServerSystemTest {
}
private String getValidIpAddress() throws IOException {
- WsClient adminWsClient = newAdminWsClient(orchestrator);
- ShowWsResponse response = ShowWsResponse.parseFrom(adminWsClient.wsConnector().call(
+ ShowWsResponse response = ShowWsResponse.parseFrom(tester.wsClient().wsConnector().call(
new GetRequest("api/server_id/show").setMediaType(MediaTypes.PROTOBUF)).contentStream());
assertThat(response.getValidIpAddressesCount()).isGreaterThan(0);
return response.getValidIpAddresses(0);
diff --git a/tests/src/test/resources/serverSystem/ServerSystemTest/url_ending_by_jsp.html b/tests/src/test/resources/serverSystem/ServerSystemTest/url_ending_by_jsp.html
index 12056550fc2..e162439dad9 100644
--- a/tests/src/test/resources/serverSystem/ServerSystemTest/url_ending_by_jsp.html
+++ b/tests/src/test/resources/serverSystem/ServerSystemTest/url_ending_by_jsp.html
@@ -29,7 +29,7 @@
<tbody>
<tr>
<td>open</td>
- <td>/dashboard/index/myproject.jsp</td>
+ <td>/dashboard?id=myproject.jsp</td>
<td></td>
</tr>
<tr>