您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

UserTester.java 8.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2023 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonarqube.ws.tester;
  21. import com.google.common.collect.MoreCollectors;
  22. import java.util.List;
  23. import java.util.Optional;
  24. import java.util.concurrent.atomic.AtomicInteger;
  25. import java.util.function.Consumer;
  26. import java.util.function.Predicate;
  27. import java.util.stream.Collectors;
  28. import javax.annotation.Nullable;
  29. import org.sonarqube.ws.UserTokens;
  30. import org.sonarqube.ws.Users;
  31. import org.sonarqube.ws.Users.CreateWsResponse.User;
  32. import org.sonarqube.ws.client.PostRequest;
  33. import org.sonarqube.ws.client.WsResponse;
  34. import org.sonarqube.ws.client.usergroups.AddUserRequest;
  35. import org.sonarqube.ws.client.users.ChangePasswordRequest;
  36. import org.sonarqube.ws.client.users.CreateRequest;
  37. import org.sonarqube.ws.client.users.SearchRequest;
  38. import org.sonarqube.ws.client.users.UpdateIdentityProviderRequest;
  39. import org.sonarqube.ws.client.users.UpdateRequest;
  40. import org.sonarqube.ws.client.users.UsersService;
  41. import org.sonarqube.ws.client.usertokens.GenerateRequest;
  42. import static java.util.Arrays.stream;
  43. public class UserTester {
  44. private static final AtomicInteger ID_GENERATOR = new AtomicInteger();
  45. private final TesterSession session;
  46. UserTester(TesterSession session) {
  47. this.session = session;
  48. }
  49. void deleteAll() {
  50. session.wsClient().users().search(new SearchRequest()).getUsersList()
  51. .stream()
  52. .filter(u -> !"admin".equals(u.getLogin()))
  53. .forEach(u -> {
  54. PostRequest request = new PostRequest("api/users/deactivate").setParam("login", u.getLogin());
  55. try (final WsResponse response = session.wsClient().wsConnector().call(request)) {
  56. response.failIfNotSuccessful();
  57. }
  58. });
  59. }
  60. public final String generateToken(String login) {
  61. int id = ID_GENERATOR.getAndIncrement();
  62. String name = "token" + id;
  63. session.wsClient().userTokens().generate(new GenerateRequest().setLogin(login).setName(name));
  64. return name;
  65. }
  66. public final String generateToken(String login, String type, @Nullable String projectKey) {
  67. int id = ID_GENERATOR.getAndIncrement();
  68. String name = "token" + id;
  69. UserTokens.GenerateWsResponse response = session.wsClient().userTokens()
  70. .generate(new GenerateRequest().setLogin(login).setName(name).setType(type).setProjectKey(projectKey));
  71. return response.getToken();
  72. }
  73. public final String generateToken(String login, Consumer<GenerateRequest>... populators) {
  74. int id = ID_GENERATOR.getAndIncrement();
  75. String name = "token" + id;
  76. GenerateRequest generateRequest = new GenerateRequest()
  77. .setName(name)
  78. .setLogin(login);
  79. stream(populators).forEach(p -> p.accept(generateRequest));
  80. UserTokens.GenerateWsResponse response = session.wsClient().userTokens()
  81. .generate(generateRequest);
  82. return response.getToken();
  83. }
  84. @SafeVarargs
  85. public final User generate(Consumer<CreateRequest>... populators) {
  86. int id = ID_GENERATOR.getAndIncrement();
  87. String login = "login" + id;
  88. CreateRequest request = new CreateRequest()
  89. .setLogin(login)
  90. .setPassword(login)
  91. .setName("name" + id)
  92. .setEmail(id + "@test.com");
  93. stream(populators).forEach(p -> p.accept(request));
  94. return service().create(request).getUser();
  95. }
  96. @SafeVarargs
  97. public final User generateApplicationCreator(Consumer<CreateRequest>... populators) {
  98. User u = generate(populators);
  99. session.wsClient().permissions().addUser(
  100. new org.sonarqube.ws.client.permissions.AddUserRequest()
  101. .setLogin(u.getLogin())
  102. .setPermission("applicationcreator"));
  103. return u;
  104. }
  105. @SafeVarargs
  106. public final User generatePortfolioCreator(Consumer<CreateRequest>... populators) {
  107. User u = generate(populators);
  108. session.wsClient().permissions().addUser(
  109. new org.sonarqube.ws.client.permissions.AddUserRequest()
  110. .setLogin(u.getLogin())
  111. .setPermission("portfoliocreator"));
  112. return u;
  113. }
  114. /**
  115. * For standalone mode only
  116. */
  117. @SafeVarargs
  118. public final User generateAdministrator(Consumer<CreateRequest>... populators) {
  119. User user = generate(populators);
  120. session.wsClient().permissions().addUser(new org.sonarqube.ws.client.permissions.AddUserRequest().setLogin(user.getLogin()).setPermission("admin"));
  121. session.wsClient().userGroups().addUser(new AddUserRequest().setLogin(user.getLogin()).setName("sonar-administrators"));
  122. return user;
  123. }
  124. public UsersService service() {
  125. return session.wsClient().users();
  126. }
  127. public Optional<Users.SearchWsResponse.User> getByExternalLogin(String externalLogin) {
  128. return getAllUsers().stream()
  129. .filter(user -> user.getExternalIdentity().equals(externalLogin))
  130. .collect(MoreCollectors.toOptional());
  131. }
  132. public List<Users.SearchWsResponse.User> getAllUsers() {
  133. return service().search(new SearchRequest()).getUsersList();
  134. }
  135. public Optional<Users.SearchWsResponse.User> getDeactivatedUserByExternalLogin(String externalLogin) {
  136. return getAllDeactivatedUsers().stream()
  137. .filter(user -> user.getExternalIdentity().equals(externalLogin))
  138. .collect(MoreCollectors.toOptional());
  139. }
  140. public List<Users.SearchWsResponse.User> getAllDeactivatedUsers() {
  141. return service().search(new SearchRequest().setDeactivated(true)).getUsersList();
  142. }
  143. public Optional<Users.SearchWsResponse.User> getByLogin(String login) {
  144. return queryForUser(login, t -> t.getLogin().equals(login));
  145. }
  146. public Optional<Users.SearchWsResponse.User> getByEmail(String email) {
  147. return queryForUser(email, t -> t.getEmail().equals(email));
  148. }
  149. public Optional<Users.SearchWsResponse.User> getByName(String name) {
  150. return queryForUser(name, t -> t.getName().equals(name));
  151. }
  152. public void changePassword(String login, String previousPassword, String newPassword) {
  153. service().changePassword(new ChangePasswordRequest().setLogin(login).setPreviousPassword(previousPassword).setPassword(newPassword));
  154. }
  155. private Optional<Users.SearchWsResponse.User> queryForUser(String login, Predicate<Users.SearchWsResponse.User> predicate) {
  156. List<Users.SearchWsResponse.User> users = session.wsClient().users().search(new SearchRequest().setQ(login)).getUsersList().stream()
  157. .filter(predicate).collect(Collectors.toList());
  158. if (users.size() == 1) {
  159. return Optional.of(users.get(0));
  160. }
  161. return Optional.empty();
  162. }
  163. public final String generateLogin() {
  164. int id = ID_GENERATOR.getAndIncrement();
  165. return "login" + id;
  166. }
  167. public final String generateProviderId() {
  168. int id = ID_GENERATOR.getAndIncrement();
  169. return "providerId" + id;
  170. }
  171. public final String generateEmail() {
  172. int id = ID_GENERATOR.getAndIncrement();
  173. return "email" + id + "@test.com";
  174. }
  175. public void updateIdentityProvider(String login, String externalProvider, @Nullable String externalIdentity) {
  176. session.wsClient().users().updateIdentityProvider(
  177. new UpdateIdentityProviderRequest()
  178. .setLogin(login)
  179. .setNewExternalProvider(externalProvider)
  180. .setNewExternalIdentity(externalIdentity));
  181. }
  182. public void update(String login, Consumer<UpdateRequest>... updaters) {
  183. UpdateRequest updateRequest = new UpdateRequest();
  184. updateRequest.setLogin(login);
  185. stream(updaters).forEach(p -> p.accept(updateRequest));
  186. session.wsClient().users().update(updateRequest);
  187. }
  188. }