test_task_repositories.py 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. # Copyright 2023 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.core.data._data_sql_repository import _DataSQLRepository
  14. from taipy.core.exceptions import ModelNotFound
  15. from taipy.core.task._task_fs_repository import _TaskFSRepository
  16. from taipy.core.task._task_sql_repository import _TaskSQLRepository
  17. from taipy.core.task.task import Task, TaskId
  18. class TestTaskFSRepository:
  19. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  20. def test_save_and_load(self, data_node, repo, init_sql_repo):
  21. repository = repo()
  22. _DataSQLRepository()._save(data_node)
  23. task = Task("task_config_id", {}, print, [data_node], [data_node])
  24. repository._save(task)
  25. obj = repository._load(task.id)
  26. assert isinstance(obj, Task)
  27. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  28. def test_exists(self, data_node, repo, init_sql_repo):
  29. repository = repo()
  30. _DataSQLRepository()._save(data_node)
  31. task = Task("task_config_id", {}, print, [data_node], [data_node])
  32. repository._save(task)
  33. assert repository._exists(task.id)
  34. assert not repository._exists("not-existed-task")
  35. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  36. def test_load_all(self, data_node, repo, init_sql_repo):
  37. repository = repo()
  38. _DataSQLRepository()._save(data_node)
  39. task = Task("task_config_id", {}, print, [data_node], [data_node])
  40. for i in range(10):
  41. task.id = TaskId(f"task-{i}")
  42. repository._save(task)
  43. data_nodes = repository._load_all()
  44. assert len(data_nodes) == 10
  45. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  46. def test_load_all_with_filters(self, data_node, repo, init_sql_repo):
  47. repository = repo()
  48. _DataSQLRepository()._save(data_node)
  49. task = Task("task_config_id", {}, print, [data_node], [data_node])
  50. for i in range(10):
  51. task.id = TaskId(f"task-{i}")
  52. task._owner_id = f"owner-{i}"
  53. repository._save(task)
  54. objs = repository._load_all(filters=[{"owner_id": "owner-2"}])
  55. assert len(objs) == 1
  56. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  57. def test_delete(self, data_node, repo, init_sql_repo):
  58. repository = repo()
  59. _DataSQLRepository()._save(data_node)
  60. task = Task("task_config_id", {}, print, [data_node], [data_node])
  61. repository._save(task)
  62. repository._delete(task.id)
  63. with pytest.raises(ModelNotFound):
  64. repository._load(task.id)
  65. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  66. def test_delete_all(self, data_node, repo, init_sql_repo):
  67. repository = repo()
  68. _DataSQLRepository()._save(data_node)
  69. task = Task("task_config_id", {}, print, [data_node], [data_node])
  70. for i in range(10):
  71. task.id = TaskId(f"task-{i}")
  72. repository._save(task)
  73. assert len(repository._load_all()) == 10
  74. repository._delete_all()
  75. assert len(repository._load_all()) == 0
  76. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  77. def test_delete_many(self, data_node, repo, init_sql_repo):
  78. repository = repo()
  79. _DataSQLRepository()._save(data_node)
  80. task = Task("task_config_id", {}, print, [data_node], [data_node])
  81. for i in range(10):
  82. task.id = TaskId(f"task-{i}")
  83. repository._save(task)
  84. objs = repository._load_all()
  85. assert len(objs) == 10
  86. ids = [x.id for x in objs[:3]]
  87. repository._delete_many(ids)
  88. assert len(repository._load_all()) == 7
  89. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  90. def test_delete_by(self, data_node, repo, init_sql_repo):
  91. repository = repo()
  92. _DataSQLRepository()._save(data_node)
  93. task = Task("task_config_id", {}, print, [data_node], [data_node])
  94. # Create 5 entities with version 1.0 and 5 entities with version 2.0
  95. for i in range(10):
  96. task.id = TaskId(f"task-{i}")
  97. task._version = f"{(i+1) // 5}.0"
  98. repository._save(task)
  99. objs = repository._load_all()
  100. assert len(objs) == 10
  101. repository._delete_by("version", "1.0")
  102. assert len(repository._load_all()) == 5
  103. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  104. def test_search(self, data_node, repo, init_sql_repo):
  105. repository = repo()
  106. _DataSQLRepository()._save(data_node)
  107. task = Task("task_config_id", {}, print, [data_node], [data_node], version="random_version_number")
  108. for i in range(10):
  109. task.id = TaskId(f"task-{i}")
  110. task._owner_id = f"owner-{i}"
  111. repository._save(task)
  112. assert len(repository._load_all()) == 10
  113. objs = repository._search("owner_id", "owner-2")
  114. assert len(objs) == 1
  115. assert isinstance(objs[0], Task)
  116. objs = repository._search("owner_id", "owner-2", filters=[{"version": "random_version_number"}])
  117. assert len(objs) == 1
  118. assert isinstance(objs[0], Task)
  119. assert repository._search("owner_id", "owner-2", filters=[{"version": "non_existed_version"}]) == []
  120. @pytest.mark.parametrize("repo", [_TaskFSRepository, _TaskSQLRepository])
  121. def test_export(self, tmpdir, data_node, repo, init_sql_repo):
  122. repository = repo()
  123. _DataSQLRepository()._save(data_node)
  124. task = Task("task_config_id", {}, print, [data_node], [data_node])
  125. repository._save(task)
  126. repository._export(task.id, tmpdir.strpath)
  127. dir_path = repository.dir_path if repo == _TaskFSRepository else os.path.join(tmpdir.strpath, "task")
  128. assert os.path.exists(os.path.join(dir_path, f"{task.id}.json"))