You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CeActivityDaoTest.java 43KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2020 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.sonar.db.ce;
  21. import com.google.common.base.Function;
  22. import com.google.common.base.Strings;
  23. import com.google.common.collect.ImmutableSet;
  24. import com.tngtech.java.junit.dataprovider.DataProvider;
  25. import com.tngtech.java.junit.dataprovider.DataProviderRunner;
  26. import com.tngtech.java.junit.dataprovider.UseDataProvider;
  27. import java.util.Arrays;
  28. import java.util.Collections;
  29. import java.util.List;
  30. import java.util.Optional;
  31. import java.util.Random;
  32. import java.util.stream.IntStream;
  33. import javax.annotation.Nonnull;
  34. import javax.annotation.Nullable;
  35. import org.assertj.core.api.AbstractListAssert;
  36. import org.assertj.core.api.ObjectAssert;
  37. import org.assertj.core.groups.Tuple;
  38. import org.junit.Before;
  39. import org.junit.Rule;
  40. import org.junit.Test;
  41. import org.junit.runner.RunWith;
  42. import org.sonar.api.impl.utils.TestSystem2;
  43. import org.sonar.core.util.CloseableIterator;
  44. import org.sonar.core.util.UuidFactoryFast;
  45. import org.sonar.core.util.stream.MoreCollectors;
  46. import org.sonar.db.DbSession;
  47. import org.sonar.db.DbTester;
  48. import org.sonar.db.Pagination;
  49. import org.sonar.db.component.BranchDto;
  50. import org.sonar.db.project.ProjectDto;
  51. import static java.util.Collections.singleton;
  52. import static java.util.Collections.singletonList;
  53. import static org.apache.commons.lang.RandomStringUtils.randomAlphabetic;
  54. import static org.assertj.core.api.Assertions.assertThat;
  55. import static org.assertj.core.api.Assertions.tuple;
  56. import static org.sonar.db.Pagination.forPage;
  57. import static org.sonar.db.ce.CeActivityDto.Status.CANCELED;
  58. import static org.sonar.db.ce.CeActivityDto.Status.FAILED;
  59. import static org.sonar.db.ce.CeActivityDto.Status.SUCCESS;
  60. import static org.sonar.db.ce.CeQueueDto.Status.PENDING;
  61. import static org.sonar.db.ce.CeQueueTesting.makeInProgress;
  62. import static org.sonar.db.ce.CeTaskTypes.REPORT;
  63. @RunWith(DataProviderRunner.class)
  64. public class CeActivityDaoTest {
  65. private static final String MAINCOMPONENT_1 = randomAlphabetic(12);
  66. private static final String MAINCOMPONENT_2 = randomAlphabetic(13);
  67. private static final String COMPONENT_1 = randomAlphabetic(14);
  68. private static final long INITIAL_TIME = 1_450_000_000_000L;
  69. private final TestSystem2 system2 = new TestSystem2().setNow(INITIAL_TIME);
  70. @Rule
  71. public DbTester db = DbTester.create(system2);
  72. private final DbSession dbSession = db.getSession();
  73. private final CeActivityDao underTest = new CeActivityDao(system2);
  74. @Before
  75. public void setup() {
  76. system2.setNow(INITIAL_TIME);
  77. }
  78. @Test
  79. public void test_insert() {
  80. CeActivityDto inserted = insert("TASK_1", REPORT, COMPONENT_1, MAINCOMPONENT_1, SUCCESS);
  81. Optional<CeActivityDto> saved = underTest.selectByUuid(db.getSession(), "TASK_1");
  82. assertThat(saved).isPresent();
  83. CeActivityDto dto = saved.get();
  84. assertThat(dto.getUuid()).isEqualTo("TASK_1");
  85. assertThat(dto.getMainComponentUuid()).isEqualTo(MAINCOMPONENT_1);
  86. assertThat(dto.getComponentUuid()).isEqualTo(COMPONENT_1);
  87. assertThat(dto.getStatus()).isEqualTo(SUCCESS);
  88. assertThat(dto.getSubmitterUuid()).isEqualTo("submitter uuid");
  89. assertThat(dto.getSubmittedAt()).isEqualTo(1_450_000_000_000L);
  90. assertThat(dto.getWorkerUuid()).isEqualTo("worker uuid");
  91. assertThat(dto.getIsLast()).isTrue();
  92. assertThat(dto.getMainIsLast()).isTrue();
  93. assertThat(dto.getIsLastKey()).isEqualTo("REPORT" + COMPONENT_1);
  94. assertThat(dto.getMainIsLastKey()).isEqualTo("REPORT" + MAINCOMPONENT_1);
  95. assertThat(dto.getCreatedAt()).isEqualTo(INITIAL_TIME + 1);
  96. assertThat(dto.getStartedAt()).isEqualTo(1_500_000_000_000L);
  97. assertThat(dto.getExecutedAt()).isEqualTo(1_500_000_000_500L);
  98. assertThat(dto.getExecutionTimeMs()).isEqualTo(500L);
  99. assertThat(dto.getAnalysisUuid()).isEqualTo(inserted.getAnalysisUuid());
  100. assertThat(dto.toString()).isNotEmpty();
  101. assertThat(dto.getErrorMessage()).isNull();
  102. assertThat(dto.getErrorStacktrace()).isNull();
  103. assertThat(dto.getErrorType()).isNull();
  104. assertThat(dto.isHasScannerContext()).isFalse();
  105. assertThat(dto.getWarningCount()).isZero();
  106. }
  107. @Test
  108. public void selectByUuid_populates_warning_count() {
  109. CeActivityDto[] tasks = {
  110. insert("TASK_1", REPORT, "PROJECT_1", SUCCESS),
  111. insert("TASK_2", REPORT, "PROJECT_1", SUCCESS),
  112. insert("TASK_3", REPORT, "PROJECT_1", SUCCESS)
  113. };
  114. int moreThan1 = 2 + new Random().nextInt(5);
  115. insertWarnings(tasks[0], moreThan1);
  116. insertWarnings(tasks[1], 0);
  117. insertWarnings(tasks[2], 1);
  118. assertThat(underTest.selectByUuid(dbSession, tasks[0].getUuid()).get().getWarningCount()).isEqualTo(moreThan1);
  119. assertThat(underTest.selectByUuid(dbSession, tasks[1].getUuid()).get().getWarningCount()).isEqualTo(0);
  120. assertThat(underTest.selectByUuid(dbSession, tasks[2].getUuid()).get().getWarningCount()).isEqualTo(1);
  121. }
  122. private void insertWarnings(CeActivityDto task, int warningCount) {
  123. IntStream.range(0, warningCount).forEach(i -> db.getDbClient().ceTaskMessageDao().insert(dbSession,
  124. new CeTaskMessageDto()
  125. .setUuid(UuidFactoryFast.getInstance().create())
  126. .setTaskUuid(task.getUuid())
  127. .setMessage("message_" + task.getUuid() + "_" + i)
  128. .setType(CeTaskMessageType.GENERIC)
  129. .setCreatedAt(task.getUuid().hashCode() + i)));
  130. db.commit();
  131. }
  132. @Test
  133. @UseDataProvider("notCanceledStatus")
  134. public void insert_resets_is_last_and_main_is_last_fields_based_on_component_and_main_component(CeActivityDto.Status status) {
  135. String project1 = randomAlphabetic(5);
  136. String branch11 = randomAlphabetic(6);
  137. String project2 = randomAlphabetic(8);
  138. String branch21 = randomAlphabetic(9);
  139. String type = randomAlphabetic(10);
  140. String task1Project1 = insertAndCommit(newUuid(), type, project1, project1, status).getUuid();
  141. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(true, true));
  142. String task2Project1 = insertAndCommit(newUuid(), type, project1, project1, status).getUuid();
  143. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  144. assertIsLastAndMainIsLastFieldsOf(task2Project1).containsOnly(tuple(true, true));
  145. String task1Branch11 = insertAndCommit(newUuid(), type, branch11, project1, status).getUuid();
  146. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  147. assertIsLastAndMainIsLastFieldsOf(task2Project1).containsOnly(tuple(true, false));
  148. assertIsLastAndMainIsLastFieldsOf(task1Branch11).containsOnly(tuple(true, true));
  149. String task2Branch11 = insertAndCommit(newUuid(), type, branch11, project1, status).getUuid();
  150. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  151. assertIsLastAndMainIsLastFieldsOf(task2Project1).containsOnly(tuple(true, false));
  152. assertIsLastAndMainIsLastFieldsOf(task1Branch11).containsOnly(tuple(false, false));
  153. assertIsLastAndMainIsLastFieldsOf(task2Branch11).containsOnly(tuple(true, true));
  154. String task1Project2 = insertAndCommit(newUuid(), type, project2, project2, status).getUuid();
  155. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  156. assertIsLastAndMainIsLastFieldsOf(task2Project1).containsOnly(tuple(true, false));
  157. assertIsLastAndMainIsLastFieldsOf(task1Branch11).containsOnly(tuple(false, false));
  158. assertIsLastAndMainIsLastFieldsOf(task2Branch11).containsOnly(tuple(true, true));
  159. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(true, true));
  160. String task2Project2 = insertAndCommit(newUuid(), type, project2, project2, status).getUuid();
  161. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  162. assertIsLastAndMainIsLastFieldsOf(task2Project1).containsOnly(tuple(true, false));
  163. assertIsLastAndMainIsLastFieldsOf(task1Branch11).containsOnly(tuple(false, false));
  164. assertIsLastAndMainIsLastFieldsOf(task2Branch11).containsOnly(tuple(true, true));
  165. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(false, false));
  166. assertIsLastAndMainIsLastFieldsOf(task2Project2).containsOnly(tuple(true, true));
  167. String task1Branch21 = insertAndCommit(newUuid(), type, branch21, project2, status).getUuid();
  168. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  169. assertIsLastAndMainIsLastFieldsOf(task2Project1).containsOnly(tuple(true, false));
  170. assertIsLastAndMainIsLastFieldsOf(task1Branch11).containsOnly(tuple(false, false));
  171. assertIsLastAndMainIsLastFieldsOf(task2Branch11).containsOnly(tuple(true, true));
  172. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(false, false));
  173. assertIsLastAndMainIsLastFieldsOf(task2Project2).containsOnly(tuple(true, false));
  174. assertIsLastAndMainIsLastFieldsOf(task1Branch21).containsOnly(tuple(true, true));
  175. String task3project1 = insertAndCommit(newUuid(), type, project1, project1, status).getUuid();
  176. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  177. assertIsLastAndMainIsLastFieldsOf(task2Project1).containsOnly(tuple(false, false));
  178. assertIsLastAndMainIsLastFieldsOf(task1Branch11).containsOnly(tuple(false, false));
  179. assertIsLastAndMainIsLastFieldsOf(task2Branch11).containsOnly(tuple(true, false));
  180. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(false, false));
  181. assertIsLastAndMainIsLastFieldsOf(task2Project2).containsOnly(tuple(true, false));
  182. assertIsLastAndMainIsLastFieldsOf(task1Branch21).containsOnly(tuple(true, true));
  183. assertIsLastAndMainIsLastFieldsOf(task3project1).containsOnly(tuple(true, true));
  184. }
  185. @Test
  186. @UseDataProvider("notCanceledStatus")
  187. public void insert_resets_is_last_and_main_is_last_fields_based_on_type(CeActivityDto.Status status) {
  188. String type1 = randomAlphabetic(10);
  189. String type2 = randomAlphabetic(11);
  190. String project = randomAlphabetic(5);
  191. String branch = randomAlphabetic(6);
  192. String type1Project1 = insertAndCommit(newUuid(), type1, project, project, status).getUuid();
  193. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  194. String type2Project1 = insertAndCommit(newUuid(), type2, project, project, status).getUuid();
  195. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  196. assertIsLastAndMainIsLastFieldsOf(type2Project1).containsOnly(tuple(true, true));
  197. String type2Project2 = insertAndCommit(newUuid(), type2, project, project, status).getUuid();
  198. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  199. assertIsLastAndMainIsLastFieldsOf(type2Project1).containsOnly(tuple(false, false));
  200. assertIsLastAndMainIsLastFieldsOf(type2Project2).containsOnly(tuple(true, true));
  201. String type1Branch1 = insertAndCommit(newUuid(), type1, branch, project, status).getUuid();
  202. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, false));
  203. assertIsLastAndMainIsLastFieldsOf(type2Project1).containsOnly(tuple(false, false));
  204. assertIsLastAndMainIsLastFieldsOf(type2Project2).containsOnly(tuple(true, true));
  205. assertIsLastAndMainIsLastFieldsOf(type1Branch1).containsOnly(tuple(true, true));
  206. String type2Branch1 = insertAndCommit(newUuid(), type2, branch, project, status).getUuid();
  207. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, false));
  208. assertIsLastAndMainIsLastFieldsOf(type2Project1).containsOnly(tuple(false, false));
  209. assertIsLastAndMainIsLastFieldsOf(type2Project2).containsOnly(tuple(true, false));
  210. assertIsLastAndMainIsLastFieldsOf(type1Branch1).containsOnly(tuple(true, true));
  211. assertIsLastAndMainIsLastFieldsOf(type2Branch1).containsOnly(tuple(true, true));
  212. String type2Branch2 = insertAndCommit(newUuid(), type2, branch, project, status).getUuid();
  213. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, false));
  214. assertIsLastAndMainIsLastFieldsOf(type2Project1).containsOnly(tuple(false, false));
  215. assertIsLastAndMainIsLastFieldsOf(type2Project2).containsOnly(tuple(true, false));
  216. assertIsLastAndMainIsLastFieldsOf(type1Branch1).containsOnly(tuple(true, true));
  217. assertIsLastAndMainIsLastFieldsOf(type2Branch1).containsOnly(tuple(false, false));
  218. assertIsLastAndMainIsLastFieldsOf(type2Branch2).containsOnly(tuple(true, true));
  219. }
  220. @Test
  221. @UseDataProvider("notCanceledStatus")
  222. public void insert_resets_is_last_and_main_is_last_fields_based_on_component_or_not(CeActivityDto.Status status) {
  223. String project = randomAlphabetic(5);
  224. String type1 = randomAlphabetic(11);
  225. String type2 = randomAlphabetic(11);
  226. String type1Project1 = insertAndCommit(newUuid(), type1, project, project, status).getUuid();
  227. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  228. String type1NoProject1 = insertAndCommit(newUuid(), type1, null, null, status).getUuid();
  229. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  230. assertIsLastAndMainIsLastFieldsOf(type1NoProject1).containsOnly(tuple(true, true));
  231. String type1NoProject2 = insertAndCommit(newUuid(), type1, null, null, status).getUuid();
  232. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  233. assertIsLastAndMainIsLastFieldsOf(type1NoProject1).containsOnly(tuple(false, false));
  234. assertIsLastAndMainIsLastFieldsOf(type1NoProject2).containsOnly(tuple(true, true));
  235. String type2NoProject1 = insertAndCommit(newUuid(), type2, null, null, status).getUuid();
  236. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  237. assertIsLastAndMainIsLastFieldsOf(type1NoProject1).containsOnly(tuple(false, false));
  238. assertIsLastAndMainIsLastFieldsOf(type1NoProject2).containsOnly(tuple(true, true));
  239. assertIsLastAndMainIsLastFieldsOf(type2NoProject1).containsOnly(tuple(true, true));
  240. String type2NoProject2 = insertAndCommit(newUuid(), type2, null, null, status).getUuid();
  241. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(true, true));
  242. assertIsLastAndMainIsLastFieldsOf(type1NoProject1).containsOnly(tuple(false, false));
  243. assertIsLastAndMainIsLastFieldsOf(type1NoProject2).containsOnly(tuple(true, true));
  244. assertIsLastAndMainIsLastFieldsOf(type2NoProject1).containsOnly(tuple(false, false));
  245. assertIsLastAndMainIsLastFieldsOf(type2NoProject2).containsOnly(tuple(true, true));
  246. String type1Project2 = insertAndCommit(newUuid(), type1, project, project, status).getUuid();
  247. assertIsLastAndMainIsLastFieldsOf(type1Project1).containsOnly(tuple(false, false));
  248. assertIsLastAndMainIsLastFieldsOf(type1NoProject1).containsOnly(tuple(false, false));
  249. assertIsLastAndMainIsLastFieldsOf(type1NoProject2).containsOnly(tuple(true, true));
  250. assertIsLastAndMainIsLastFieldsOf(type2NoProject1).containsOnly(tuple(false, false));
  251. assertIsLastAndMainIsLastFieldsOf(type2NoProject2).containsOnly(tuple(true, true));
  252. assertIsLastAndMainIsLastFieldsOf(type1Project2).containsOnly(tuple(true, true));
  253. }
  254. @Test
  255. @UseDataProvider("notCanceledStatus")
  256. public void insert_does_not_resets_is_last_and_main_is_last_fields_if_status_is_CANCELED(CeActivityDto.Status status) {
  257. String project = randomAlphabetic(5);
  258. String branch = randomAlphabetic(6);
  259. String type = randomAlphabetic(10);
  260. String task1Project1 = insertAndCommit(newUuid(), type, project, project, status).getUuid();
  261. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(true, true));
  262. String task1Project2 = insertAndCommit(newUuid(), type, project, project, status).getUuid();
  263. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  264. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(true, true));
  265. String task1Project3 = insertAndCommit(newUuid(), type, project, project, CANCELED).getUuid();
  266. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  267. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(true, true));
  268. assertIsLastAndMainIsLastFieldsOf(task1Project3).containsOnly(tuple(false, false));
  269. String task1Branch1 = insertAndCommit(newUuid(), type, branch, project, status).getUuid();
  270. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  271. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(true, false));
  272. assertIsLastAndMainIsLastFieldsOf(task1Project3).containsOnly(tuple(false, false));
  273. assertIsLastAndMainIsLastFieldsOf(task1Branch1).containsOnly(tuple(true, true));
  274. String task1Branch2 = insertAndCommit(newUuid(), type, branch, project, CANCELED).getUuid();
  275. assertIsLastAndMainIsLastFieldsOf(task1Project1).containsOnly(tuple(false, false));
  276. assertIsLastAndMainIsLastFieldsOf(task1Project2).containsOnly(tuple(true, false));
  277. assertIsLastAndMainIsLastFieldsOf(task1Project3).containsOnly(tuple(false, false));
  278. assertIsLastAndMainIsLastFieldsOf(task1Branch1).containsOnly(tuple(true, true));
  279. assertIsLastAndMainIsLastFieldsOf(task1Branch2).containsOnly(tuple(false, false));
  280. }
  281. @DataProvider
  282. public static Object[][] notCanceledStatus() {
  283. return Arrays.stream(CeActivityDto.Status.values())
  284. .filter(t -> t != CANCELED)
  285. .map(t -> new Object[] {t})
  286. .toArray(Object[][]::new);
  287. }
  288. private AbstractListAssert<?, List<? extends Tuple>, Tuple, ObjectAssert<Tuple>> assertIsLastAndMainIsLastFieldsOf(String taskUuid) {
  289. return assertThat(db.select("select is_last as \"IS_LAST\", main_is_last as \"MAIN_IS_LAST\" from ce_activity where uuid='" + taskUuid + "'"))
  290. .extracting(t -> toBoolean(t.get("IS_LAST")), t -> toBoolean(t.get("MAIN_IS_LAST")));
  291. }
  292. private static boolean toBoolean(Object o) {
  293. if (o instanceof Boolean) {
  294. return (Boolean) o;
  295. }
  296. if (o instanceof Long) {
  297. Long longBoolean = (Long) o;
  298. return longBoolean.equals(1L);
  299. }
  300. throw new IllegalArgumentException("Unsupported object type returned for boolean: " + o.getClass());
  301. }
  302. @Test
  303. public void test_insert_of_errorMessage_of_1_000_chars() {
  304. CeActivityDto dto = createActivityDto("TASK_1", REPORT, COMPONENT_1, MAINCOMPONENT_1, FAILED)
  305. .setErrorMessage(Strings.repeat("x", 1_000));
  306. underTest.insert(db.getSession(), dto);
  307. Optional<CeActivityDto> saved = underTest.selectByUuid(db.getSession(), "TASK_1");
  308. assertThat(saved.get().getErrorMessage()).isEqualTo(dto.getErrorMessage());
  309. }
  310. @Test
  311. public void test_insert_of_errorMessage_of_1_001_chars_is_truncated_to_1000() {
  312. String expected = Strings.repeat("x", 1_000);
  313. CeActivityDto dto = createActivityDto("TASK_1", REPORT, COMPONENT_1, MAINCOMPONENT_1, FAILED)
  314. .setErrorMessage(expected + "y");
  315. underTest.insert(db.getSession(), dto);
  316. Optional<CeActivityDto> saved = underTest.selectByUuid(db.getSession(), "TASK_1");
  317. assertThat(saved.get().getErrorMessage()).isEqualTo(expected);
  318. }
  319. @Test
  320. public void test_insert_error_message_and_stacktrace() {
  321. CeActivityDto dto = createActivityDto("TASK_1", REPORT, COMPONENT_1, MAINCOMPONENT_1, FAILED)
  322. .setErrorStacktrace("error stack");
  323. underTest.insert(db.getSession(), dto);
  324. Optional<CeActivityDto> saved = underTest.selectByUuid(db.getSession(), "TASK_1");
  325. CeActivityDto read = saved.get();
  326. assertThat(read.getErrorMessage()).isEqualTo(dto.getErrorMessage());
  327. assertThat(read.getErrorStacktrace()).isEqualTo(dto.getErrorStacktrace());
  328. assertThat(read.getErrorType()).isNotNull().isEqualTo(dto.getErrorType());
  329. }
  330. @Test
  331. public void test_insert_error_message_only() {
  332. CeActivityDto dto = createActivityDto("TASK_1", REPORT, COMPONENT_1, MAINCOMPONENT_1, FAILED);
  333. underTest.insert(db.getSession(), dto);
  334. Optional<CeActivityDto> saved = underTest.selectByUuid(db.getSession(), "TASK_1");
  335. CeActivityDto read = saved.get();
  336. assertThat(read.getErrorMessage()).isEqualTo(read.getErrorMessage());
  337. assertThat(read.getErrorStacktrace()).isNull();
  338. }
  339. @Test
  340. public void insert_must_set_relevant_is_last_field() {
  341. // only a single task on MAINCOMPONENT_1 -> is_last=true
  342. insert("TASK_1", REPORT, MAINCOMPONENT_1, SUCCESS);
  343. assertThat(underTest.selectByUuid(db.getSession(), "TASK_1").get().getIsLast()).isTrue();
  344. // only a single task on MAINCOMPONENT_2 -> is_last=true
  345. insert("TASK_2", REPORT, MAINCOMPONENT_2, SUCCESS);
  346. assertThat(underTest.selectByUuid(db.getSession(), "TASK_2").get().getIsLast()).isTrue();
  347. // two tasks on MAINCOMPONENT_1, the most recent one is TASK_3
  348. insert("TASK_3", REPORT, MAINCOMPONENT_1, FAILED);
  349. assertThat(underTest.selectByUuid(db.getSession(), "TASK_1").get().getIsLast()).isFalse();
  350. assertThat(underTest.selectByUuid(db.getSession(), "TASK_2").get().getIsLast()).isTrue();
  351. assertThat(underTest.selectByUuid(db.getSession(), "TASK_3").get().getIsLast()).isTrue();
  352. // inserting a cancelled task does not change the last task
  353. insert("TASK_4", REPORT, MAINCOMPONENT_1, CANCELED);
  354. assertThat(underTest.selectByUuid(db.getSession(), "TASK_1").get().getIsLast()).isFalse();
  355. assertThat(underTest.selectByUuid(db.getSession(), "TASK_2").get().getIsLast()).isTrue();
  356. assertThat(underTest.selectByUuid(db.getSession(), "TASK_3").get().getIsLast()).isTrue();
  357. assertThat(underTest.selectByUuid(db.getSession(), "TASK_4").get().getIsLast()).isFalse();
  358. }
  359. @Test
  360. public void test_selectByQuery() {
  361. insert("TASK_1", REPORT, MAINCOMPONENT_1, SUCCESS);
  362. insert("TASK_2", REPORT, MAINCOMPONENT_1, FAILED);
  363. insert("TASK_3", REPORT, MAINCOMPONENT_2, SUCCESS);
  364. insert("TASK_4", "views", null, SUCCESS);
  365. // no filters
  366. CeTaskQuery query = new CeTaskQuery().setStatuses(Collections.emptyList());
  367. List<CeActivityDto> dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(10));
  368. assertThat(dtos).extracting("uuid").containsExactly("TASK_4", "TASK_3", "TASK_2", "TASK_1");
  369. // select by component uuid
  370. query = new CeTaskQuery().setMainComponentUuid(MAINCOMPONENT_1);
  371. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  372. assertThat(dtos).extracting("uuid").containsExactly("TASK_2", "TASK_1");
  373. // select by status
  374. query = new CeTaskQuery().setStatuses(singletonList(SUCCESS.name()));
  375. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  376. assertThat(dtos).extracting("uuid").containsExactly("TASK_4", "TASK_3", "TASK_1");
  377. // select by type
  378. query = new CeTaskQuery().setType(REPORT);
  379. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  380. assertThat(dtos).extracting("uuid").containsExactly("TASK_3", "TASK_2", "TASK_1");
  381. query = new CeTaskQuery().setType("views");
  382. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  383. assertThat(dtos).extracting("uuid").containsExactly("TASK_4");
  384. // select by multiple conditions
  385. query = new CeTaskQuery().setType(REPORT).setOnlyCurrents(true).setMainComponentUuid(MAINCOMPONENT_1);
  386. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  387. assertThat(dtos).extracting("uuid").containsExactly("TASK_2");
  388. }
  389. @Test
  390. public void test_selectByQuery_verify_order_if_same_date() {
  391. system2.setNow(INITIAL_TIME);
  392. insert("TASK_1", REPORT, MAINCOMPONENT_1, SUCCESS);
  393. system2.setNow(INITIAL_TIME);
  394. insert("TASK_2", REPORT, MAINCOMPONENT_1, FAILED);
  395. system2.setNow(INITIAL_TIME);
  396. insert("TASK_3", REPORT, MAINCOMPONENT_2, SUCCESS);
  397. system2.setNow(INITIAL_TIME);
  398. insert("TASK_4", "views", null, SUCCESS);
  399. // no filters
  400. CeTaskQuery query = new CeTaskQuery().setStatuses(Collections.emptyList());
  401. List<CeActivityDto> dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(10));
  402. assertThat(dtos).extracting("uuid").containsExactly("TASK_4", "TASK_3", "TASK_2", "TASK_1");
  403. // select by component uuid
  404. query = new CeTaskQuery().setMainComponentUuid(MAINCOMPONENT_1);
  405. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  406. assertThat(dtos).extracting("uuid").containsExactly("TASK_2", "TASK_1");
  407. // select by status
  408. query = new CeTaskQuery().setStatuses(singletonList(SUCCESS.name()));
  409. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  410. assertThat(dtos).extracting("uuid").containsExactly("TASK_4", "TASK_3", "TASK_1");
  411. // select by type
  412. query = new CeTaskQuery().setType(REPORT);
  413. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  414. assertThat(dtos).extracting("uuid").containsExactly("TASK_3", "TASK_2", "TASK_1");
  415. query = new CeTaskQuery().setType("views");
  416. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  417. assertThat(dtos).extracting("uuid").containsExactly("TASK_4");
  418. // select by multiple conditions
  419. query = new CeTaskQuery().setType(REPORT).setOnlyCurrents(true).setMainComponentUuid(MAINCOMPONENT_1);
  420. dtos = underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100));
  421. assertThat(dtos).extracting("uuid").containsExactly("TASK_2");
  422. }
  423. @Test
  424. public void selectByQuery_does_not_populate_errorStacktrace_field() {
  425. insert("TASK_1", REPORT, MAINCOMPONENT_1, FAILED);
  426. underTest.insert(db.getSession(), createActivityDto("TASK_2", REPORT, COMPONENT_1, MAINCOMPONENT_1, FAILED).setErrorStacktrace("some stack"));
  427. List<CeActivityDto> dtos = underTest.selectByQuery(db.getSession(), new CeTaskQuery().setMainComponentUuid(MAINCOMPONENT_1), forPage(1).andSize(100));
  428. assertThat(dtos)
  429. .hasSize(2)
  430. .extracting("errorStacktrace").containsOnly((String) null);
  431. }
  432. @Test
  433. public void selectByQuery_populates_hasScannerContext_flag() {
  434. insert("TASK_1", REPORT, MAINCOMPONENT_1, SUCCESS);
  435. CeActivityDto dto2 = insert("TASK_2", REPORT, MAINCOMPONENT_2, SUCCESS);
  436. insertScannerContext(dto2.getUuid());
  437. CeActivityDto dto = underTest.selectByQuery(db.getSession(), new CeTaskQuery().setMainComponentUuid(MAINCOMPONENT_1), forPage(1).andSize(100)).iterator().next();
  438. assertThat(dto.isHasScannerContext()).isFalse();
  439. dto = underTest.selectByQuery(db.getSession(), new CeTaskQuery().setMainComponentUuid(MAINCOMPONENT_2), forPage(1).andSize(100)).iterator().next();
  440. assertThat(dto.isHasScannerContext()).isTrue();
  441. }
  442. @Test
  443. public void selectByQuery_populates_warningCount() {
  444. CeActivityDto[] tasks = {
  445. insert("TASK_1", REPORT, "PROJECT_1", SUCCESS),
  446. insert("TASK_2", REPORT, "PROJECT_1", FAILED),
  447. insert("TASK_3", REPORT, "PROJECT_2", SUCCESS),
  448. insert("TASK_4", "views", null, SUCCESS)
  449. };
  450. int moreThan1 = 2 + new Random().nextInt(5);
  451. insertWarnings(tasks[0], moreThan1);
  452. insertWarnings(tasks[1], 3);
  453. insertWarnings(tasks[2], 1);
  454. insertWarnings(tasks[3], 6);
  455. // no filters
  456. CeTaskQuery query = new CeTaskQuery().setStatuses(Collections.emptyList());
  457. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(10)))
  458. .extracting(CeActivityDto::getUuid, CeActivityDto::getWarningCount)
  459. .containsExactly(tuple("TASK_4", 6), tuple("TASK_3", 1), tuple("TASK_2", 3), tuple("TASK_1", moreThan1));
  460. // select by component uuid
  461. query = new CeTaskQuery().setMainComponentUuid("PROJECT_1");
  462. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100)))
  463. .extracting(CeActivityDto::getUuid, CeActivityDto::getWarningCount)
  464. .containsExactly(tuple("TASK_2", 3), tuple("TASK_1", moreThan1));
  465. // select by status
  466. query = new CeTaskQuery().setStatuses(singletonList(SUCCESS.name()));
  467. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100)))
  468. .extracting(CeActivityDto::getUuid, CeActivityDto::getWarningCount)
  469. .containsExactly(tuple("TASK_4", 6), tuple("TASK_3", 1), tuple("TASK_1", moreThan1));
  470. // select by type
  471. query = new CeTaskQuery().setType(REPORT);
  472. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100)))
  473. .extracting(CeActivityDto::getUuid, CeActivityDto::getWarningCount)
  474. .containsExactly(tuple("TASK_3", 1), tuple("TASK_2", 3), tuple("TASK_1", moreThan1));
  475. query = new CeTaskQuery().setType("views");
  476. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100)))
  477. .extracting(CeActivityDto::getUuid, CeActivityDto::getWarningCount)
  478. .containsExactly(tuple("TASK_4", 6));
  479. // select by multiple conditions
  480. query = new CeTaskQuery().setType(REPORT).setOnlyCurrents(true).setMainComponentUuid("PROJECT_1");
  481. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(100)))
  482. .extracting(CeActivityDto::getUuid, CeActivityDto::getWarningCount)
  483. .containsExactly(tuple("TASK_2", 3));
  484. }
  485. @Test
  486. public void selectByQuery_is_paginated_and_return_results_sorted_from_last_to_first() {
  487. insert("TASK_1", REPORT, MAINCOMPONENT_1, SUCCESS);
  488. insert("TASK_2", REPORT, MAINCOMPONENT_1, FAILED);
  489. insert("TASK_3", REPORT, MAINCOMPONENT_2, SUCCESS);
  490. insert("TASK_4", "views", null, SUCCESS);
  491. assertThat(selectPageOfUuids(forPage(1).andSize(1))).containsExactly("TASK_4");
  492. assertThat(selectPageOfUuids(forPage(2).andSize(1))).containsExactly("TASK_3");
  493. assertThat(selectPageOfUuids(forPage(1).andSize(3))).containsExactly("TASK_4", "TASK_3", "TASK_2");
  494. assertThat(selectPageOfUuids(forPage(1).andSize(4))).containsExactly("TASK_4", "TASK_3", "TASK_2", "TASK_1");
  495. assertThat(selectPageOfUuids(forPage(2).andSize(3))).containsExactly("TASK_1");
  496. assertThat(selectPageOfUuids(forPage(1).andSize(100))).containsExactly("TASK_4", "TASK_3", "TASK_2", "TASK_1");
  497. assertThat(selectPageOfUuids(forPage(5).andSize(2))).isEmpty();
  498. }
  499. @Test
  500. public void selectByQuery_no_results_if_shortcircuited_by_component_uuids() {
  501. insert("TASK_1", REPORT, MAINCOMPONENT_1, SUCCESS);
  502. CeTaskQuery query = new CeTaskQuery();
  503. query.setMainComponentUuids(Collections.emptyList());
  504. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(1))).isEmpty();
  505. }
  506. @Test
  507. public void select_and_count_by_date() {
  508. insertWithDates("UUID1", 1_450_000_000_000L, 1_470_000_000_000L);
  509. insertWithDates("UUID2", 1_460_000_000_000L, 1_480_000_000_000L);
  510. // search by min submitted date
  511. CeTaskQuery query = new CeTaskQuery().setMinSubmittedAt(1_455_000_000_000L);
  512. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(5))).extracting("uuid").containsOnly("UUID2");
  513. // search by max executed date
  514. query = new CeTaskQuery().setMaxExecutedAt(1_475_000_000_000L);
  515. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(5))).extracting("uuid").containsOnly("UUID1");
  516. // search by both dates
  517. query = new CeTaskQuery()
  518. .setMinSubmittedAt(1_400_000_000_000L)
  519. .setMaxExecutedAt(1_475_000_000_000L);
  520. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(5))).extracting("uuid").containsOnly("UUID1");
  521. }
  522. @Test
  523. public void select_by_minExecutedAt() {
  524. insertWithDates("UUID1", 1_450_000_000_000L, 1_470_000_000_000L);
  525. insertWithDates("UUID2", 1_460_000_000_000L, 1_480_000_000_000L);
  526. CeTaskQuery query = new CeTaskQuery().setMinExecutedAt(1_460_000_000_000L);
  527. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(5))).extracting("uuid").containsExactlyInAnyOrder("UUID1", "UUID2");
  528. query = new CeTaskQuery().setMinExecutedAt(1_475_000_000_000L);
  529. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(5))).extracting("uuid").containsExactlyInAnyOrder("UUID2");
  530. query = new CeTaskQuery().setMinExecutedAt(1_485_000_000_000L);
  531. assertThat(underTest.selectByQuery(db.getSession(), query, forPage(1).andSize(5))).isEmpty();
  532. }
  533. private void insertWithDates(String uuid, long submittedAt, long executedAt) {
  534. CeQueueDto queueDto = new CeQueueDto();
  535. queueDto.setUuid(uuid);
  536. queueDto.setTaskType("fake");
  537. CeActivityDto dto = new CeActivityDto(queueDto);
  538. dto.setStatus(SUCCESS);
  539. dto.setSubmittedAt(submittedAt);
  540. dto.setExecutedAt(executedAt);
  541. underTest.insert(db.getSession(), dto);
  542. }
  543. @Test
  544. public void selectOlderThan() {
  545. insertWithCreationDate("TASK_1", 1_450_000_000_000L);
  546. insertWithCreationDate("TASK_2", 1_460_000_000_000L);
  547. insertWithCreationDate("TASK_3", 1_470_000_000_000L);
  548. List<CeActivityDto> dtos = underTest.selectOlderThan(db.getSession(), 1_465_000_000_000L);
  549. assertThat(dtos).extracting("uuid").containsOnly("TASK_1", "TASK_2");
  550. }
  551. @Test
  552. public void selectOlder_populates_hasScannerContext_flag() {
  553. insertWithCreationDate("TASK_1", 1_450_000_000_000L);
  554. CeActivityDto dto2 = insertWithCreationDate("TASK_2", 1_450_000_000_000L);
  555. insertScannerContext(dto2.getUuid());
  556. List<CeActivityDto> dtos = underTest.selectOlderThan(db.getSession(), 1_465_000_000_000L);
  557. assertThat(dtos).hasSize(2);
  558. dtos.forEach((dto) -> assertThat(dto.isHasScannerContext()).isEqualTo(dto.getUuid().equals("TASK_2")));
  559. }
  560. @Test
  561. public void selectOlderThan_does_not_populate_errorStacktrace() {
  562. insert("TASK_1", REPORT, MAINCOMPONENT_1, FAILED);
  563. underTest.insert(db.getSession(), createActivityDto("TASK_2", REPORT, COMPONENT_1, MAINCOMPONENT_1, FAILED).setErrorStacktrace("some stack"));
  564. List<CeActivityDto> dtos = underTest.selectOlderThan(db.getSession(), system2.now() + 1_000_000L);
  565. assertThat(dtos)
  566. .hasSize(2)
  567. .extracting("errorStacktrace").containsOnly((String) null);
  568. }
  569. @Test
  570. public void selectOlderThan_does_not_populate_warningCount() {
  571. CeActivityDto activity1 = insert("TASK_1", REPORT, "PROJECT_1", FAILED);
  572. insertWarnings(activity1, 10);
  573. CeActivityDto activity2 = insert("TASK_2", REPORT, "PROJECT_1", SUCCESS);
  574. insertWarnings(activity2, 1);
  575. List<CeActivityDto> dtos = underTest.selectOlderThan(db.getSession(), system2.now() + 1_000_000L);
  576. assertThat(dtos)
  577. .hasSize(2)
  578. .extracting(CeActivityDto::getWarningCount)
  579. .containsOnly(0);
  580. }
  581. @Test
  582. public void deleteByUuids() {
  583. insert("TASK_1", "REPORT", MAINCOMPONENT_1, SUCCESS);
  584. insert("TASK_2", "REPORT", MAINCOMPONENT_1, SUCCESS);
  585. insert("TASK_3", "REPORT", MAINCOMPONENT_1, SUCCESS);
  586. underTest.deleteByUuids(db.getSession(), ImmutableSet.of("TASK_1", "TASK_3"));
  587. assertThat(underTest.selectByUuid(db.getSession(), "TASK_1").isPresent()).isFalse();
  588. assertThat(underTest.selectByUuid(db.getSession(), "TASK_2")).isPresent();
  589. assertThat(underTest.selectByUuid(db.getSession(), "TASK_3").isPresent()).isFalse();
  590. }
  591. @Test
  592. public void deleteByUuids_does_nothing_if_uuid_does_not_exist() {
  593. insert("TASK_1", "REPORT", MAINCOMPONENT_1, SUCCESS);
  594. // must not fail
  595. underTest.deleteByUuids(db.getSession(), singleton("TASK_2"));
  596. assertThat(underTest.selectByUuid(db.getSession(), "TASK_1")).isPresent();
  597. }
  598. @Test
  599. public void count_last_by_status_and_main_component_uuid() {
  600. insert("TASK_1", CeTaskTypes.REPORT, MAINCOMPONENT_1, SUCCESS);
  601. // component 2
  602. insert("TASK_2", CeTaskTypes.REPORT, MAINCOMPONENT_2, SUCCESS);
  603. // status failed
  604. insert("TASK_3", CeTaskTypes.REPORT, MAINCOMPONENT_1, FAILED);
  605. // status canceled
  606. insert("TASK_4", CeTaskTypes.REPORT, MAINCOMPONENT_1, CANCELED);
  607. insert("TASK_5", CeTaskTypes.REPORT, MAINCOMPONENT_1, SUCCESS);
  608. db.commit();
  609. assertThat(underTest.countLastByStatusAndMainComponentUuid(dbSession, SUCCESS, MAINCOMPONENT_1)).isEqualTo(1);
  610. assertThat(underTest.countLastByStatusAndMainComponentUuid(dbSession, SUCCESS, null)).isEqualTo(2);
  611. }
  612. @Test
  613. public void selectLastByComponentUuidAndTaskType_returns_task_of_given_type() {
  614. insert("TASK_1", "VIEW_REFRESH", MAINCOMPONENT_1, MAINCOMPONENT_1, SUCCESS);
  615. insert("TASK_2", CeTaskTypes.REPORT, MAINCOMPONENT_1, MAINCOMPONENT_1, SUCCESS);
  616. insert("TASK_3", "PROJECT_EXPORT", MAINCOMPONENT_1, MAINCOMPONENT_1, SUCCESS);
  617. insert("TASK_4", "PROJECT_IMPORT", MAINCOMPONENT_1, MAINCOMPONENT_1, SUCCESS);
  618. db.commit();
  619. Optional<CeActivityDto> result = underTest.selectLastByComponentUuidAndTaskType(db.getSession(), MAINCOMPONENT_1, "PROJECT_EXPORT");
  620. assertThat(result).hasValueSatisfying(value -> assertThat(value.getUuid()).isEqualTo("TASK_3"));
  621. }
  622. @Test
  623. public void selectLastByComponentUuidAndTaskType_returns_empty_if_task_of_given_type_does_not_exist() {
  624. insert("TASK_1", CeTaskTypes.REPORT, MAINCOMPONENT_1, SUCCESS);
  625. db.commit();
  626. Optional<CeActivityDto> result = underTest.selectLastByComponentUuidAndTaskType(db.getSession(), MAINCOMPONENT_1, "PROJECT_EXPORT");
  627. assertThat(result).isEmpty();
  628. }
  629. @Test
  630. public void selectByTaskType() {
  631. insert("TASK_1", CeTaskTypes.REPORT, MAINCOMPONENT_1, SUCCESS);
  632. insert("TASK_2", CeTaskTypes.BRANCH_ISSUE_SYNC, MAINCOMPONENT_1, SUCCESS);
  633. db.commit();
  634. assertThat(underTest.selectByTaskType(db.getSession(), CeTaskTypes.REPORT))
  635. .extracting("uuid")
  636. .containsExactly("TASK_1");
  637. assertThat(underTest.selectByTaskType(db.getSession(), CeTaskTypes.BRANCH_ISSUE_SYNC))
  638. .extracting("uuid")
  639. .containsExactly("TASK_2");
  640. assertThat(underTest.selectByTaskType(db.getSession(), "unknown-type")).isEmpty();
  641. }
  642. @Test
  643. public void hasAnyFailedIssueSyncTask() {
  644. assertThat(underTest.hasAnyFailedIssueSyncTask(db.getSession())).isFalse();
  645. insert("TASK_1", REPORT, MAINCOMPONENT_1, SUCCESS);
  646. insert("TASK_2", REPORT, MAINCOMPONENT_1, FAILED);
  647. ProjectDto projectDto1 = db.components()
  648. .insertPrivateProjectDto(db.getDefaultOrganization(), branchDto -> branchDto.setNeedIssueSync(false));
  649. insert("TASK_3", CeTaskTypes.BRANCH_ISSUE_SYNC, projectDto1.getUuid(), projectDto1.getUuid(), SUCCESS);
  650. ProjectDto projectDto2 = db.components()
  651. .insertPrivateProjectDto(db.getDefaultOrganization(), branchDto -> branchDto.setNeedIssueSync(false));
  652. insert("TASK_4", CeTaskTypes.BRANCH_ISSUE_SYNC, projectDto2.getUuid(), projectDto2.getUuid(), SUCCESS);
  653. assertThat(underTest.hasAnyFailedIssueSyncTask(db.getSession())).isFalse();
  654. ProjectDto projectDto3 = db.components().insertPrivateProjectDto(db.getDefaultOrganization(), branchDto -> branchDto.setNeedIssueSync(false));
  655. insert("TASK_5", CeTaskTypes.BRANCH_ISSUE_SYNC, projectDto3.getUuid(), projectDto3.getUuid(), SUCCESS);
  656. BranchDto projectBranch = db.components()
  657. .insertProjectBranch(projectDto3, branchDto -> branchDto.setNeedIssueSync(true));
  658. insert("TASK_6", CeTaskTypes.BRANCH_ISSUE_SYNC, projectBranch.getUuid(), projectDto3.getUuid(), FAILED);
  659. // failed task and project branch still exists and need sync
  660. assertThat(underTest.hasAnyFailedIssueSyncTask(db.getSession())).isTrue();
  661. // assume branch has been re-analysed
  662. db.getDbClient().branchDao().updateNeedIssueSync(db.getSession(), projectBranch.getUuid(), false);
  663. assertThat(underTest.hasAnyFailedIssueSyncTask(db.getSession())).isFalse();
  664. // assume branch has been deleted
  665. db.getDbClient().purgeDao().deleteBranch(db.getSession(), projectBranch.getUuid());
  666. // associated branch does not exist, so there is no failures - either it has been deleted or purged or reanalysed
  667. assertThat(underTest.hasAnyFailedIssueSyncTask(db.getSession())).isFalse();
  668. }
  669. private CeActivityDto insert(String uuid, String type, @Nullable String mainComponentUuid, CeActivityDto.Status status) {
  670. return insert(uuid, type, mainComponentUuid, mainComponentUuid, status);
  671. }
  672. private CeActivityDto insertAndCommit(String uuid, String type, @Nullable String componentUuid, @Nullable String mainComponentUuid, CeActivityDto.Status status) {
  673. CeActivityDto res = insert(uuid, type, componentUuid, mainComponentUuid, status);
  674. db.commit();
  675. return res;
  676. }
  677. private CeActivityDto insert(String uuid, String type, @Nullable String componentUuid, @Nullable String mainComponentUuid, CeActivityDto.Status status) {
  678. CeActivityDto dto = createActivityDto(uuid, type, componentUuid, mainComponentUuid, status);
  679. system2.tick();
  680. underTest.insert(db.getSession(), dto);
  681. return dto;
  682. }
  683. private CeActivityDto createActivityDto(String uuid, String type, @Nullable String componentUuid, @Nullable String mainComponentUuid, CeActivityDto.Status status) {
  684. CeQueueDto creating = new CeQueueDto();
  685. creating.setUuid(uuid);
  686. creating.setStatus(PENDING);
  687. creating.setTaskType(type);
  688. creating.setComponentUuid(componentUuid);
  689. creating.setMainComponentUuid(mainComponentUuid);
  690. creating.setSubmitterUuid("submitter uuid");
  691. creating.setCreatedAt(system2.now());
  692. db.getDbClient().ceQueueDao().insert(dbSession, creating);
  693. makeInProgress(dbSession, "worker uuid", 1_400_000_000_000L, creating);
  694. CeQueueDto ceQueueDto = db.getDbClient().ceQueueDao().selectByUuid(dbSession, uuid).get();
  695. CeActivityDto dto = new CeActivityDto(ceQueueDto);
  696. dto.setStatus(status);
  697. dto.setStartedAt(1_500_000_000_000L);
  698. dto.setExecutedAt(1_500_000_000_500L);
  699. dto.setExecutionTimeMs(500L);
  700. dto.setAnalysisUuid(uuid + "_2");
  701. if (status == FAILED) {
  702. dto.setErrorMessage("error msg for " + uuid);
  703. dto.setErrorType("anErrorType");
  704. }
  705. return dto;
  706. }
  707. private CeActivityDto insertWithCreationDate(String uuid, long date) {
  708. CeQueueDto queueDto = new CeQueueDto();
  709. queueDto.setUuid(uuid);
  710. queueDto.setTaskType("fake");
  711. CeActivityDto dto = new CeActivityDto(queueDto);
  712. dto.setStatus(SUCCESS);
  713. dto.setAnalysisUuid(uuid + "_AA");
  714. system2.setNow(date);
  715. underTest.insert(db.getSession(), dto);
  716. return dto;
  717. }
  718. private void insertScannerContext(String taskUuid) {
  719. db.getDbClient().ceScannerContextDao().insert(dbSession, taskUuid, CloseableIterator.from(singletonList("scanner context of " + taskUuid).iterator()));
  720. dbSession.commit();
  721. }
  722. private List<String> selectPageOfUuids(Pagination pagination) {
  723. return underTest.selectByQuery(db.getSession(), new CeTaskQuery(), pagination).stream()
  724. .map(CeActivityToUuid.INSTANCE::apply)
  725. .collect(MoreCollectors.toList());
  726. }
  727. private enum CeActivityToUuid implements Function<CeActivityDto, String> {
  728. INSTANCE;
  729. @Override
  730. public String apply(@Nonnull CeActivityDto input) {
  731. return input.getUuid();
  732. }
  733. }
  734. private static String newUuid() {
  735. return UuidFactoryFast.getInstance().create();
  736. }
  737. }