test_submission_repositories.py 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  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. import os
  12. import pytest
  13. from taipy.config.config import Config
  14. from taipy.core.data._data_manager_factory import _DataManagerFactory
  15. from taipy.core.exceptions import ModelNotFound
  16. from taipy.core.job._job_manager_factory import _JobManagerFactory
  17. from taipy.core.submission._submission_manager_factory import _SubmissionManagerFactory
  18. from taipy.core.submission.submission import Submission
  19. from taipy.core.task._task_manager_factory import _TaskManagerFactory
  20. from taipy.core.task.task import Task
  21. from tests.core.conftest import init_sql_repo
  22. def configure_fs_repo():
  23. Config.configure_core(repository_type="default")
  24. def configure_sql_repo():
  25. init_sql_repo # noqa: B018
  26. class TestSubmissionRepository:
  27. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  28. def test_save_and_load(self, data_node, job, configure_repo):
  29. configure_repo()
  30. _DataManagerFactory._build_manager()._repository._save(data_node)
  31. task = Task("task_config_id", {}, print, [data_node], [data_node])
  32. _TaskManagerFactory._build_manager()._repository._save(task)
  33. job._task = task
  34. _JobManagerFactory._build_manager()._repository._save(job)
  35. submission = Submission(
  36. task.id, task._ID_PREFIX, task.config_id, properties={"debug": True, "log": "log_file", "retry_note": 5}
  37. )
  38. submission_repository = _SubmissionManagerFactory._build_manager()._repository
  39. submission_repository._save(submission)
  40. submission.jobs = [job]
  41. obj = submission_repository._load(submission.id)
  42. assert isinstance(obj, Submission)
  43. assert obj.entity_id == task.id
  44. assert obj.entity_type == task._ID_PREFIX
  45. assert obj.entity_config_id == task.config_id
  46. assert obj.properties == {"debug": True, "log": "log_file", "retry_note": 5}
  47. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  48. def test_exists(self, configure_repo):
  49. configure_repo()
  50. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id")
  51. submission_repository = _SubmissionManagerFactory._build_manager()._repository
  52. submission_repository._save(submission)
  53. assert submission_repository._exists(submission.id)
  54. assert not submission_repository._exists("not-existed-submission")
  55. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  56. def test_load_all(self, configure_repo):
  57. configure_repo()
  58. repository = _SubmissionManagerFactory._build_manager()._repository
  59. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id")
  60. for i in range(10):
  61. submission.id = f"submission-{i}"
  62. repository._save(submission)
  63. submissions = repository._load_all()
  64. assert len(submissions) == 10
  65. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  66. def test_delete(self, configure_repo):
  67. configure_repo()
  68. repository = _SubmissionManagerFactory._build_manager()._repository
  69. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id")
  70. repository._save(submission)
  71. repository._delete(submission.id)
  72. with pytest.raises(ModelNotFound):
  73. repository._load(submission.id)
  74. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  75. def test_delete_all(self, configure_repo):
  76. configure_repo()
  77. submission_repository = _SubmissionManagerFactory._build_manager()._repository
  78. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id")
  79. for i in range(10):
  80. submission.id = f"submission-{i}"
  81. submission_repository._save(submission)
  82. assert len(submission_repository._load_all()) == 10
  83. submission_repository._delete_all()
  84. assert len(submission_repository._load_all()) == 0
  85. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  86. def test_delete_many(self, configure_repo):
  87. configure_repo()
  88. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id")
  89. submission_repository = _SubmissionManagerFactory._build_manager()._repository
  90. for i in range(10):
  91. submission.id = f"submission-{i}"
  92. submission_repository._save(submission)
  93. objs = submission_repository._load_all()
  94. assert len(objs) == 10
  95. ids = [x.id for x in objs[:3]]
  96. submission_repository._delete_many(ids)
  97. assert len(submission_repository._load_all()) == 7
  98. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  99. def test_delete_by(self, configure_repo):
  100. configure_repo()
  101. # Create 5 entities with version 1.0 and 5 entities with version 2.0
  102. submission_repository = _SubmissionManagerFactory._build_manager()._repository
  103. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id")
  104. for i in range(10):
  105. submission.id = f"submission-{i}"
  106. submission._version = f"{(i+1) // 5}.0"
  107. submission_repository._save(submission)
  108. objs = submission_repository._load_all()
  109. assert len(objs) == 10
  110. submission_repository._delete_by("version", "1.0")
  111. assert len(submission_repository._load_all()) == 5
  112. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  113. def test_search(self, configure_repo):
  114. configure_repo()
  115. submission_repository = _SubmissionManagerFactory._build_manager()._repository
  116. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id", version="random_version_number")
  117. for i in range(10):
  118. submission.id = f"submission-{i}"
  119. submission_repository._save(submission)
  120. assert len(submission_repository._load_all()) == 10
  121. objs = submission_repository._search("id", "submission-2")
  122. assert len(objs) == 1
  123. assert isinstance(objs[0], Submission)
  124. objs = submission_repository._search("id", "submission-2", filters=[{"version": "random_version_number"}])
  125. assert len(objs) == 1
  126. assert isinstance(objs[0], Submission)
  127. assert submission_repository._search("id", "submission-2", filters=[{"version": "non_existed_version"}]) == []
  128. @pytest.mark.parametrize("configure_repo", [configure_fs_repo, configure_sql_repo])
  129. def test_export(self, tmpdir, configure_repo):
  130. configure_repo()
  131. repository = _SubmissionManagerFactory._build_manager()._repository
  132. submission = Submission("entity_id", "ENTITY_TYPE", "entity_config_id")
  133. repository._save(submission)
  134. repository._export(submission.id, tmpdir.strpath)
  135. dir_path = (
  136. repository.dir_path
  137. if Config.core.repository_type == "default"
  138. else os.path.join(tmpdir.strpath, "submission")
  139. )
  140. assert os.path.exists(os.path.join(dir_path, f"{submission.id}.json"))