test_submission_manager.py 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. # Copyright 2021-2024 Avaiga Private Limited
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
  4. # the License. You may obtain a copy of the License at
  5. #
  6. # http://www.apache.org/licenses/LICENSE-2.0
  7. #
  8. # Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
  9. # an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
  10. # specific language governing permissions and limitations under the License.
  11. from datetime import datetime
  12. from time import sleep
  13. import pytest
  14. from taipy.core._version._version_manager_factory import _VersionManagerFactory
  15. from taipy.core.exceptions.exceptions import SubmissionNotDeletedException
  16. from taipy.core.job._job_manager_factory import _JobManagerFactory
  17. from taipy.core.job.job import Job
  18. from taipy.core.submission._submission_manager_factory import _SubmissionManagerFactory
  19. from taipy.core.submission.submission import Submission
  20. from taipy.core.submission.submission_status import SubmissionStatus
  21. from taipy.core.task._task_manager_factory import _TaskManagerFactory
  22. from taipy.core.task.task import Task
  23. def test_create_submission(scenario):
  24. submission_1 = _SubmissionManagerFactory._build_manager()._create(
  25. scenario.id, scenario._ID_PREFIX, scenario.config_id
  26. )
  27. assert submission_1.id is not None
  28. assert submission_1.entity_id == scenario.id
  29. assert submission_1.jobs == []
  30. assert isinstance(submission_1.creation_date, datetime)
  31. assert submission_1._submission_status == SubmissionStatus.SUBMITTED
  32. def test_get_submission():
  33. submission_manager = _SubmissionManagerFactory._build_manager()
  34. assert submission_manager._get("random_submission_id") is None
  35. submission_1 = submission_manager._create("entity_id", "ENTITY_TYPE", "entity_config_id")
  36. submission_2 = submission_manager._get(submission_1.id)
  37. assert submission_1.id == submission_2.id
  38. assert submission_1.entity_id == submission_2.entity_id == "entity_id"
  39. assert submission_1.jobs == submission_2.jobs
  40. assert submission_1.creation_date == submission_2.creation_date
  41. assert submission_1.submission_status == submission_2.submission_status
  42. def test_get_all_submission():
  43. submission_manager = _SubmissionManagerFactory._build_manager()
  44. version_manager = _VersionManagerFactory._build_manager()
  45. submission_manager._set(
  46. Submission(
  47. "entity_id",
  48. "entity_type",
  49. "entity_config_id",
  50. "submission_id",
  51. version=version_manager._get_latest_version(),
  52. )
  53. )
  54. for version_name in ["abc", "xyz"]:
  55. for i in range(10):
  56. submission_manager._set(
  57. Submission(
  58. "entity_id",
  59. "entity_type",
  60. "entity_config_id",
  61. f"submission_{version_name}_{i}",
  62. version=f"{version_name}",
  63. )
  64. )
  65. assert len(submission_manager._get_all()) == 1
  66. version_manager._set_experiment_version("xyz")
  67. version_manager._set_experiment_version("abc")
  68. assert len(submission_manager._get_all()) == 10
  69. assert len(submission_manager._get_all("abc")) == 10
  70. assert len(submission_manager._get_all("xyz")) == 10
  71. def test_get_latest_submission():
  72. task_1 = Task("task_config_1", {}, print, id="task_id_1")
  73. task_2 = Task("task_config_2", {}, print, id="task_id_2")
  74. submission_manager = _SubmissionManagerFactory._build_manager()
  75. submission_1 = submission_manager._create(task_1.id, task_1._ID_PREFIX, task_1.config_id)
  76. assert submission_manager._get_latest(task_1) == submission_1
  77. assert submission_manager._get_latest(task_2) is None
  78. sleep(0.01) # Comparison is based on time, precision on Windows is not enough important
  79. submission_2 = submission_manager._create(task_2.id, task_2._ID_PREFIX, task_2.config_id)
  80. assert submission_manager._get_latest(task_1) == submission_1
  81. assert submission_manager._get_latest(task_2) == submission_2
  82. sleep(0.01) # Comparison is based on time, precision on Windows is not enough important
  83. submission_3 = submission_manager._create(task_1.id, task_1._ID_PREFIX, task_1.config_id)
  84. assert submission_manager._get_latest(task_1) == submission_3
  85. assert submission_manager._get_latest(task_2) == submission_2
  86. sleep(0.01) # Comparison is based on time, precision on Windows is not enough important
  87. submission_4 = submission_manager._create(task_2.id, task_2._ID_PREFIX, task_2.config_id)
  88. assert submission_manager._get_latest(task_1) == submission_3
  89. assert submission_manager._get_latest(task_2) == submission_4
  90. def test_delete_submission():
  91. submission_manager = _SubmissionManagerFactory._build_manager()
  92. submission = Submission("entity_id", "entity_type", "entity_config_id", "submission_id")
  93. submission_manager._set(submission)
  94. with pytest.raises(SubmissionNotDeletedException):
  95. submission_manager._delete(submission.id)
  96. submission.submission_status = SubmissionStatus.COMPLETED
  97. for i in range(10):
  98. submission_manager._set(Submission("entity_id", "entity_type", "entity_config_id", f"submission_{i}"))
  99. assert len(submission_manager._get_all()) == 11
  100. assert isinstance(submission_manager._get(submission.id), Submission)
  101. submission_manager._delete(submission.id)
  102. assert len(submission_manager._get_all()) == 10
  103. assert submission_manager._get(submission.id) is None
  104. submission_manager._delete_all()
  105. assert len(submission_manager._get_all()) == 0
  106. def test_is_deletable():
  107. submission_manager = _SubmissionManagerFactory._build_manager()
  108. submission = Submission("entity_id", "entity_type", "entity_config_id", "submission_id")
  109. submission_manager._set(submission)
  110. assert len(submission_manager._get_all()) == 1
  111. assert submission._submission_status == SubmissionStatus.SUBMITTED
  112. assert not submission.is_deletable()
  113. assert not submission_manager._is_deletable(submission)
  114. assert not submission_manager._is_deletable(submission.id)
  115. submission.submission_status = SubmissionStatus.UNDEFINED
  116. assert submission.submission_status == SubmissionStatus.UNDEFINED
  117. assert submission.is_deletable()
  118. assert submission_manager._is_deletable(submission)
  119. assert submission_manager._is_deletable(submission.id)
  120. submission.submission_status = SubmissionStatus.CANCELED
  121. assert submission.submission_status == SubmissionStatus.CANCELED
  122. assert submission.is_deletable()
  123. assert submission_manager._is_deletable(submission)
  124. assert submission_manager._is_deletable(submission.id)
  125. submission.submission_status = SubmissionStatus.FAILED
  126. assert submission.submission_status == SubmissionStatus.FAILED
  127. assert submission.is_deletable()
  128. assert submission_manager._is_deletable(submission)
  129. assert submission_manager._is_deletable(submission.id)
  130. submission.submission_status = SubmissionStatus.BLOCKED
  131. assert submission.submission_status == SubmissionStatus.BLOCKED
  132. assert not submission.is_deletable()
  133. assert not submission_manager._is_deletable(submission)
  134. assert not submission_manager._is_deletable(submission.id)
  135. submission.submission_status = SubmissionStatus.RUNNING
  136. assert submission.submission_status == SubmissionStatus.RUNNING
  137. assert not submission.is_deletable()
  138. assert not submission_manager._is_deletable(submission)
  139. assert not submission_manager._is_deletable(submission.id)
  140. submission.submission_status = SubmissionStatus.PENDING
  141. assert submission.submission_status == SubmissionStatus.PENDING
  142. assert not submission.is_deletable()
  143. assert not submission_manager._is_deletable(submission)
  144. assert not submission_manager._is_deletable(submission.id)
  145. submission.submission_status = SubmissionStatus.COMPLETED
  146. assert submission.submission_status == SubmissionStatus.COMPLETED
  147. assert submission.is_deletable()
  148. assert submission_manager._is_deletable(submission)
  149. assert submission_manager._is_deletable(submission.id)
  150. def test_hard_delete():
  151. submission_manager = _SubmissionManagerFactory._build_manager()
  152. job_manager = _JobManagerFactory._build_manager()
  153. task_manager = _TaskManagerFactory._build_manager()
  154. task = Task("task_config_id", {}, print)
  155. submission = Submission(task.id, task._ID_PREFIX, task.config_id, "SUBMISSION_submission_id")
  156. job_1 = Job("JOB_job_id_1", task, submission.id, submission.entity_id) # will be deleted with submission
  157. job_2 = Job("JOB_job_id_2", task, "SUBMISSION_submission_id_2", submission.entity_id) # will not be deleted
  158. submission.jobs = [job_1]
  159. task_manager._set(task)
  160. submission_manager._set(submission)
  161. job_manager._set(job_1)
  162. job_manager._set(job_2)
  163. assert len(job_manager._get_all()) == 2
  164. assert len(submission_manager._get_all()) == 1
  165. submission_manager._hard_delete(submission.id)
  166. assert len(job_manager._get_all()) == 1
  167. assert len(submission_manager._get_all()) == 0