Browse Source
* add initial api tests for process definition controller * Update * Add test cases for project page * Remove unrelated stuff * Remove useless imports * Add project api test case to github workflow matrix3.2.1-prepare
Eric Gao
1 year ago
committed by
GitHub
16 changed files with 426 additions and 7 deletions
@ -0,0 +1,211 @@
|
||||
/* |
||||
* Licensed to Apache Software Foundation (ASF) under one or more contributor |
||||
* license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright |
||||
* ownership. Apache Software Foundation (ASF) licenses this file to you under |
||||
* the Apache License, Version 2.0 (the "License"); you may |
||||
* not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, |
||||
* software distributed under the License is distributed on an |
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
||||
* KIND, either express or implied. See the License for the |
||||
* specific language governing permissions and limitations |
||||
* under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.api.test.cases; |
||||
|
||||
import org.apache.dolphinscheduler.api.test.core.DolphinScheduler; |
||||
import org.apache.dolphinscheduler.api.test.entity.HttpResponse; |
||||
import org.apache.dolphinscheduler.api.test.entity.LoginResponseData; |
||||
import org.apache.dolphinscheduler.api.test.pages.LoginPage; |
||||
import org.apache.dolphinscheduler.api.test.pages.project.ProjectPage; |
||||
import org.apache.dolphinscheduler.api.test.utils.JSONUtils; |
||||
import org.apache.dolphinscheduler.common.enums.UserType; |
||||
import org.apache.dolphinscheduler.dao.entity.Project; |
||||
import org.apache.dolphinscheduler.dao.entity.User; |
||||
|
||||
import org.junit.jupiter.api.AfterAll; |
||||
import org.junit.jupiter.api.Assertions; |
||||
import org.junit.jupiter.api.BeforeAll; |
||||
import org.junit.jupiter.api.Disabled; |
||||
import org.junit.jupiter.api.Order; |
||||
import org.junit.jupiter.api.Test; |
||||
|
||||
import lombok.extern.slf4j.Slf4j; |
||||
|
||||
import java.util.LinkedHashMap; |
||||
import java.util.List; |
||||
|
||||
@DolphinScheduler(composeFiles = "docker/basic/docker-compose.yaml") |
||||
@Slf4j |
||||
// TODO: Add more detailed permission control related cases after userPage test cases completed
|
||||
public class ProjectAPITest { |
||||
|
||||
private static final String username = "admin"; |
||||
|
||||
private static final String password = "dolphinscheduler123"; |
||||
|
||||
private static String sessionId; |
||||
|
||||
private static User loginUser; |
||||
|
||||
private static ProjectPage projectPage; |
||||
|
||||
@BeforeAll |
||||
public static void setup() { |
||||
LoginPage loginPage = new LoginPage(); |
||||
HttpResponse loginHttpResponse = loginPage.login(username, password); |
||||
sessionId = JSONUtils.convertValue(loginHttpResponse.getBody().getData(), LoginResponseData.class).getSessionId(); |
||||
projectPage = new ProjectPage(sessionId); |
||||
loginUser = new User(); |
||||
loginUser.setUserName("admin"); |
||||
loginUser.setId(1); |
||||
loginUser.setUserType(UserType.ADMIN_USER); |
||||
} |
||||
|
||||
@AfterAll |
||||
public static void cleanup() { |
||||
log.info("success cleanup"); |
||||
} |
||||
|
||||
@Test |
||||
@Order(1) |
||||
public void testQueryAllProjectList() { |
||||
HttpResponse queryAllProjectListResponse = projectPage.queryAllProjectList(loginUser); |
||||
Assertions.assertTrue(queryAllProjectListResponse.getBody().getSuccess()); |
||||
List<Project> projects = (List<Project>) queryAllProjectListResponse.getBody().getData(); |
||||
Assertions.assertEquals(projects.size(), 0); |
||||
} |
||||
|
||||
@Test |
||||
@Order(2) |
||||
public void testCreateProject() { |
||||
HttpResponse createProjectResponse = projectPage.createProject(loginUser, "project-test"); |
||||
Assertions.assertTrue(createProjectResponse.getBody().getSuccess()); |
||||
|
||||
HttpResponse queryAllProjectListResponse = projectPage.queryAllProjectList(loginUser); |
||||
Assertions.assertTrue(queryAllProjectListResponse.getBody().getData().toString().contains("project-test")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(3) |
||||
public void testUpdateProject() { |
||||
HttpResponse queryAllProjectListResponse = projectPage.queryAllProjectList(loginUser); |
||||
List<LinkedHashMap> projects = (List<LinkedHashMap>) queryAllProjectListResponse.getBody().getData(); |
||||
Long code = (Long) projects.get(0).get("code"); |
||||
|
||||
HttpResponse updateProjectResponse = projectPage.updateProject(loginUser, code,"project-new", loginUser.getUserName()); |
||||
Assertions.assertTrue(updateProjectResponse.getBody().getSuccess()); |
||||
|
||||
queryAllProjectListResponse = projectPage.queryAllProjectList(loginUser); |
||||
Assertions.assertFalse(queryAllProjectListResponse.getBody().getData().toString().contains("project-test")); |
||||
Assertions.assertTrue(queryAllProjectListResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(4) |
||||
public void testQueryProjectByCode() { |
||||
HttpResponse queryAllProjectListResponse = projectPage.queryAllProjectList(loginUser); |
||||
List<LinkedHashMap> projects = (List<LinkedHashMap>) queryAllProjectListResponse.getBody().getData(); |
||||
Long code = (Long) projects.get(0).get("code"); |
||||
String projectNameExpected = (String) projects.get(0).get("name"); |
||||
|
||||
HttpResponse queryProjectByCodeResponse = projectPage.queryProjectByCode(loginUser, code); |
||||
Assertions.assertTrue(queryProjectByCodeResponse.getBody().getSuccess()); |
||||
|
||||
LinkedHashMap<String, Object> project = (LinkedHashMap) queryProjectByCodeResponse.getBody().getData(); |
||||
String projectNameActual = (String) project.get("name"); |
||||
Assertions.assertEquals(projectNameExpected, projectNameActual); |
||||
} |
||||
|
||||
@Test |
||||
@Order(5) |
||||
public void testQueryProjectListPaging() { |
||||
HttpResponse queryProjectListPagingResponse = projectPage.queryProjectListPaging(loginUser, 1, 1); |
||||
Assertions.assertTrue(queryProjectListPagingResponse.getBody().getSuccess()); |
||||
Assertions.assertTrue(queryProjectListPagingResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(6) |
||||
public void testQueryProjectWithAuthorizedLevelListPaging() { |
||||
HttpResponse queryProjectWithAuthorizedLevelListPagingResponse = projectPage.queryProjectWithAuthorizedLevelListPaging(loginUser, loginUser.getId(),1, 1); |
||||
Assertions.assertTrue(queryProjectWithAuthorizedLevelListPagingResponse.getBody().getSuccess()); |
||||
Assertions.assertTrue(queryProjectWithAuthorizedLevelListPagingResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(7) |
||||
public void testQueryUnauthorizedProject() { |
||||
HttpResponse queryUnauthorizedProjectResponse = projectPage.queryUnauthorizedProject(loginUser, loginUser.getId()); |
||||
Assertions.assertTrue(queryUnauthorizedProjectResponse.getBody().getSuccess()); |
||||
// project-new was created by instead of authorized to this user, therefore, it should be in the unauthorized list
|
||||
Assertions.assertTrue(queryUnauthorizedProjectResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(8) |
||||
public void testQueryAuthorizedProject() { |
||||
HttpResponse queryAuthorizedProjectResponse = projectPage.queryAuthorizedProject(loginUser, loginUser.getId()); |
||||
Assertions.assertTrue(queryAuthorizedProjectResponse.getBody().getSuccess()); |
||||
// project-new was created by instead of authorized to this user, therefore, it should not be in the authorized list
|
||||
Assertions.assertFalse(queryAuthorizedProjectResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(9) |
||||
public void testQueryProjectWithAuthorizedLevel() { |
||||
HttpResponse queryProjectWithAuthorizedLevelResponse = projectPage.queryProjectWithAuthorizedLevel(loginUser, loginUser.getId()); |
||||
Assertions.assertTrue(queryProjectWithAuthorizedLevelResponse.getBody().getSuccess()); |
||||
// queryProjectWithAuthorizedLevel api returns a joint-set of projects both created by and authorized to the user
|
||||
Assertions.assertTrue(queryProjectWithAuthorizedLevelResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(10) |
||||
public void testQueryAuthorizedUser() { |
||||
HttpResponse queryAllProjectListResponse = projectPage.queryAllProjectList(loginUser); |
||||
List<LinkedHashMap> projects = (List<LinkedHashMap>) queryAllProjectListResponse.getBody().getData(); |
||||
Long code = (Long) projects.get(0).get("code"); |
||||
HttpResponse queryAuthorizedUserResponse = projectPage.queryAuthorizedUser(loginUser, code); |
||||
List<LinkedHashMap> users = (List<LinkedHashMap>) queryAuthorizedUserResponse.getBody().getData(); |
||||
Assertions.assertTrue(queryAuthorizedUserResponse.getBody().getSuccess()); |
||||
// admin has not authorized this project to any other users, therefore, the authorized user list should be empty
|
||||
Assertions.assertEquals(users.size(), 0); |
||||
} |
||||
|
||||
@Test |
||||
@Order(11) |
||||
public void testQueryProjectCreatedAndAuthorizedByUser() { |
||||
HttpResponse queryProjectCreatedAndAuthorizedByUserResponse = projectPage.queryProjectCreatedAndAuthorizedByUser(loginUser); |
||||
Assertions.assertTrue(queryProjectCreatedAndAuthorizedByUserResponse.getBody().getSuccess()); |
||||
// queryProjectCreatedAndAuthorizedByUser api returns a joint-set of projects both created by and authorized to the user
|
||||
Assertions.assertTrue(queryProjectCreatedAndAuthorizedByUserResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(12) |
||||
public void testQueryAllProjectListForDependent() { |
||||
HttpResponse queryAllProjectListForDependentResponse = projectPage.queryAllProjectListForDependent(loginUser); |
||||
Assertions.assertTrue(queryAllProjectListForDependentResponse.getBody().getSuccess()); |
||||
Assertions.assertTrue(queryAllProjectListForDependentResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
|
||||
@Test |
||||
@Order(13) |
||||
public void testDeleteProject() { |
||||
HttpResponse queryAllProjectListResponse = projectPage.queryAllProjectList(loginUser); |
||||
List<LinkedHashMap> projects = (List<LinkedHashMap>) queryAllProjectListResponse.getBody().getData(); |
||||
Long code = (Long) projects.get(0).get("code"); |
||||
HttpResponse queryAllProjectListForDependentResponse = projectPage.deleteProject(loginUser, code); |
||||
Assertions.assertTrue(queryAllProjectListForDependentResponse.getBody().getSuccess()); |
||||
Assertions.assertFalse(queryAllProjectListForDependentResponse.getBody().getData().toString().contains("project-new")); |
||||
} |
||||
} |
||||
|
||||
|
0
dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api.test/entity/TenantListPagingResponseData.java → dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api/test/entity/TenantListPagingResponseData.java
0
dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api.test/entity/TenantListPagingResponseData.java → dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api/test/entity/TenantListPagingResponseData.java
0
dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api.test/entity/TenantListPagingResponseTotalList.java → dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api/test/entity/TenantListPagingResponseTotalList.java
0
dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api.test/entity/TenantListPagingResponseTotalList.java → dolphinscheduler-api-test/dolphinscheduler-api-test-case/src/test/java/org/apache/dolphinscheduler/api/test/entity/TenantListPagingResponseTotalList.java
@ -0,0 +1,180 @@
|
||||
/* |
||||
* Licensed to Apache Software Foundation (ASF) under one or more contributor |
||||
* license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright |
||||
* ownership. Apache Software Foundation (ASF) licenses this file to you under |
||||
* the Apache License, Version 2.0 (the "License"); you may |
||||
* not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, |
||||
* software distributed under the License is distributed on an |
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
||||
* KIND, either express or implied. See the License for the |
||||
* specific language governing permissions and limitations |
||||
* under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.api.test.pages.project; |
||||
|
||||
import lombok.AllArgsConstructor; |
||||
|
||||
import org.apache.dolphinscheduler.api.test.core.Constants; |
||||
import org.apache.dolphinscheduler.api.test.entity.HttpResponse; |
||||
import org.apache.dolphinscheduler.api.test.utils.RequestClient; |
||||
import org.apache.dolphinscheduler.dao.entity.User; |
||||
|
||||
import java.util.HashMap; |
||||
import java.util.Map; |
||||
|
||||
@AllArgsConstructor |
||||
public final class ProjectPage { |
||||
private String sessionId; |
||||
|
||||
public HttpResponse createProject(User loginUser, String projectName) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("projectName", projectName); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.post("/projects", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryAllProjectList(User loginUser) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/list", headers, params); |
||||
} |
||||
|
||||
public HttpResponse updateProject(User loginUser, Long code, String projectName, String userName) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("projectName", projectName); |
||||
params.put("userName", userName); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
String url = String.format("/projects/%d", code); |
||||
return requestClient.put(url, headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryProjectByCode(User loginUser, Long code) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
String url = String.format("/projects/%d", code); |
||||
return requestClient.get(url, headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryProjectListPaging(User loginUser, Integer pageSize, Integer pageNo) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("pageSize", pageSize); |
||||
params.put("pageNo", pageNo); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryProjectWithAuthorizedLevelListPaging(User loginUser, Integer userId, Integer pageSize, Integer pageNo) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("userId", userId); |
||||
params.put("pageSize", pageSize); |
||||
params.put("pageNo", pageNo); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/project-with-authorized-level-list-paging", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryUnauthorizedProject(User loginUser, Integer userId) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("userId", userId); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/unauth-project", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryAuthorizedProject(User loginUser, Integer userId) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("userId", userId); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/authed-project", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryProjectWithAuthorizedLevel(User loginUser, Integer userId) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("userId", userId); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/project-with-authorized-level", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryAuthorizedUser(User loginUser, Long projectCode) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
params.put("projectCode", projectCode); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/authed-user", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryProjectCreatedAndAuthorizedByUser(User loginUser) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/created-and-authed", headers, params); |
||||
} |
||||
|
||||
public HttpResponse queryAllProjectListForDependent(User loginUser) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
return requestClient.get("/projects/list-dependent", headers, params); |
||||
} |
||||
|
||||
public HttpResponse deleteProject(User loginUser, Long code) { |
||||
Map<String, Object> params = new HashMap<>(); |
||||
params.put("loginUser", loginUser); |
||||
Map<String, String> headers = new HashMap<>(); |
||||
headers.put(Constants.SESSION_ID_KEY, sessionId); |
||||
|
||||
RequestClient requestClient = new RequestClient(); |
||||
String url = String.format("/projects/%d", code); |
||||
return requestClient.delete(url, headers, params); |
||||
} |
||||
} |
Loading…
Reference in new issue