aboutsummaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/Tester.java11
-rw-r--r--server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/UserTester.java20
-rw-r--r--server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/pageobjects/measures/MeasuresPage.java13
3 files changed, 40 insertions, 4 deletions
diff --git a/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/Tester.java b/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/Tester.java
index 50412d8bc50..f5077ad3266 100644
--- a/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/Tester.java
+++ b/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/Tester.java
@@ -39,12 +39,21 @@ import static java.util.Objects.requireNonNull;
* <li>clean-up of users between tests</li>
* <li>clean-up of session when opening a browser (cookies, local storage)</li>
* <li>quick access to {@link WsClient} instances</li>
+ * <li>clean-up of defined settings. Properties that are not defined by a plugin are not reset.</li>
* <li>helpers to generate organizations and users</li>
* </ul>
- * <p>
+ *
* Recommendation is to define a {@code @Rule} instance. If not possible, then
* {@code @ClassRule} must be used through a {@link org.junit.rules.RuleChain}
* around {@link Orchestrator}.
+ *
+ * Not supported:
+ * <ul>
+ * <li>clean-up global settings</li>
+ * <li>clean-up system administrators/roots</li>
+ * <li>clean-up default organization</li>
+ * <li>clean-up the properties that are not defined (no PropertyDefinition)</li>
+ * </ul>
*/
public class Tester extends ExternalResource implements TesterSession {
diff --git a/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/UserTester.java b/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/UserTester.java
index 5f4f4a943d0..6c57c8a81aa 100644
--- a/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/UserTester.java
+++ b/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/UserTester.java
@@ -67,6 +67,9 @@ public class UserTester {
return service().create(request.build()).getUser();
}
+ /**
+ * For standalone mode only
+ */
@SafeVarargs
public final User generateAdministrator(Consumer<CreateRequest.Builder>... populators) {
User user = generate(populators);
@@ -77,10 +80,11 @@ public class UserTester {
@SafeVarargs
public final User generateAdministrator(Organizations.Organization organization, Consumer<CreateRequest.Builder>... populators) {
+ String organizationKey = organization.getKey();
User user = generate(populators);
- session.wsClient().organizations().addMember(organization.getKey(), user.getLogin());
+ session.wsClient().organizations().addMember(organizationKey, user.getLogin());
session.wsClient().userGroups().addUser(AddUserWsRequest.builder()
- .setOrganization(organization.getKey())
+ .setOrganization(organizationKey)
.setLogin(user.getLogin())
.setName("Owners")
.build());
@@ -88,6 +92,18 @@ public class UserTester {
}
@SafeVarargs
+ public final User generateAdministratorOnDefaultOrganization(Consumer<CreateRequest.Builder>... populators) {
+ User user = generate(populators);
+ session.wsClient().organizations().addMember("default-organization", user.getLogin());
+ session.wsClient().userGroups().addUser(AddUserWsRequest.builder()
+ .setOrganization("default-organization")
+ .setLogin(user.getLogin())
+ .setName("sonar-administrators")
+ .build());
+ return user;
+ }
+
+ @SafeVarargs
public final User generateMember(Organizations.Organization organization, Consumer<CreateRequest.Builder>... populators) {
User user = generate(populators);
session.wsClient().organizations().addMember(organization.getKey(), user.getLogin());
diff --git a/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/pageobjects/measures/MeasuresPage.java b/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/pageobjects/measures/MeasuresPage.java
index f3cd21aac1b..4e39003c048 100644
--- a/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/pageobjects/measures/MeasuresPage.java
+++ b/server/sonar-qa-util/src/main/java/org/sonarqube/qa/util/pageobjects/measures/MeasuresPage.java
@@ -23,7 +23,9 @@ import com.codeborne.selenide.CollectionCondition;
import com.codeborne.selenide.Condition;
import com.codeborne.selenide.Selenide;
import com.codeborne.selenide.SelenideElement;
+import com.codeborne.selenide.WebDriverRunner;
import org.openqa.selenium.Keys;
+import org.openqa.selenium.interactions.Actions;
public class MeasuresPage {
public MeasuresPage() {
@@ -61,7 +63,16 @@ public class MeasuresPage {
}
public MeasuresPage backShortcut() {
- Selenide.$(".layout-page-header-panel").sendKeys(Keys.LEFT);
+ SelenideElement panel = Selenide.$(".layout-page-header-panel");
+
+ // panel.sendKeys(Keys.LEFT) does not work correctly on Chrome
+ // The workaround is to use Actions
+ // https://bugs.chromium.org/p/chromedriver/issues/detail?id=35
+ Actions actions = new Actions(WebDriverRunner.getWebDriver());
+ actions.moveToElement(panel);
+ actions.click();
+ actions.sendKeys(Keys.LEFT);
+ actions.build().perform();
return this;
}