fix(测试跟踪): 功能用例库跨项目查看信息为空

--bug=1023394 --user=陈建星 【测试跟踪】功能用例-公共用例库-操作-查看用例详情-点击编辑-模块未显示 https://www.tapd.cn/55049933/s/1338445
This commit is contained in:
chenjianxing 2023-02-20 17:35:59 +08:00 committed by jianxing
parent ad1f32013e
commit 05a05d4bd2
5 changed files with 64 additions and 34 deletions

View File

@ -1194,7 +1194,7 @@
<if test="request.refId != null"> <if test="request.refId != null">
and ${versionTable}.ref_id = #{request.refId} and ${versionTable}.ref_id = #{request.refId}
</if> </if>
<if test="request.versionId == null and request.refId == null"> <if test="request.versionId == null and request.refId == null and request.casePublic != true">
AND ${versionTable}.latest = 1 AND ${versionTable}.latest = 1
</if> </if>
</sql> </sql>

View File

@ -415,6 +415,7 @@ public class TestCaseService {
customFieldTestCaseService.editFields(testCase.getId(), testCase.getEditFields()); customFieldTestCaseService.editFields(testCase.getId(), testCase.getEditFields());
customFieldTestCaseService.addFields(testCase.getId(), testCase.getAddFields()); customFieldTestCaseService.addFields(testCase.getId(), testCase.getAddFields());
// latest 字段 createNewVersionOrNot 已经设置过了不更新
testCase.setLatest(null); testCase.setLatest(null);
testCaseMapper.updateByPrimaryKeySelective(testCase); testCaseMapper.updateByPrimaryKeySelective(testCase);
@ -476,10 +477,15 @@ public class TestCaseService {
if (StringUtils.isBlank(testCase.getVersionId())) { if (StringUtils.isBlank(testCase.getVersionId())) {
return; return;
} }
testCase.setLatest(false);
TestCaseExample example = new TestCaseExample(); TestCaseExample example = new TestCaseExample();
example.createCriteria().andIdEqualTo(testCase.getId()) example.createCriteria().andIdEqualTo(testCase.getId())
.andVersionIdEqualTo(testCase.getVersionId()); .andVersionIdEqualTo(testCase.getVersionId());
String defaultVersion = baseProjectVersionMapper.getDefaultVersion(testCase.getProjectId());
if (StringUtils.equalsIgnoreCase(testCase.getVersionId(), defaultVersion)) {
testCase.setLatest(false);
}
if (testCaseMapper.updateByExampleSelective(testCase, example) == 0) { if (testCaseMapper.updateByExampleSelective(testCase, example) == 0) {
// 插入新版本的数据 // 插入新版本的数据
TestCaseWithBLOBs oldTestCase = testCaseMapper.selectByPrimaryKey(testCase.getId()); TestCaseWithBLOBs oldTestCase = testCaseMapper.selectByPrimaryKey(testCase.getId());
@ -494,7 +500,7 @@ public class TestCaseService {
dealWithOtherInfoOfNewVersion(testCase, oldTestCase.getId()); dealWithOtherInfoOfNewVersion(testCase, oldTestCase.getId());
testCaseMapper.insertSelective(testCase); testCaseMapper.insertSelective(testCase);
} }
String defaultVersion = baseProjectVersionMapper.getDefaultVersion(testCase.getProjectId());
if (StringUtils.equalsIgnoreCase(testCase.getVersionId(), defaultVersion)) { if (StringUtils.equalsIgnoreCase(testCase.getVersionId(), defaultVersion)) {
checkAndSetLatestVersion(testCase.getRefId()); checkAndSetLatestVersion(testCase.getRefId());
} }

View File

@ -3,7 +3,7 @@ import {getCurrentProjectID, getCurrentWorkspaceId} from "metersphere-frontend/s
const BASE_URL = "/project_application/"; const BASE_URL = "/project_application/";
export function getProjectApplicationConfig(type) { export function getProjectApplicationConfig(type, projectId) {
let projectId = getCurrentProjectID(); projectId = projectId ? projectId : getCurrentProjectID();
return get(BASE_URL + `get/${projectId}/${type}`); return get(BASE_URL + `get/${projectId}/${type}`);
} }

View File

@ -562,7 +562,8 @@ export default {
// 1 // 1
// 2 // 2
// 3 // 3
saveType: 1 saveType: 1,
projectId: null
}; };
}, },
props: { props: {
@ -578,10 +579,10 @@ export default {
type: Boolean, type: Boolean,
default: false default: false
}, },
publicCaseId: String publicCaseId: String,
}, },
computed: { computed: {
projectId() { routeProjectId() {
let pId = this.$route.params.projectId; let pId = this.$route.params.projectId;
return pId ? pId : getCurrentProjectID(); return pId ? pId : getCurrentProjectID();
}, },
@ -682,9 +683,9 @@ export default {
if (this.form.id) { if (this.form.id) {
store.testCaseMap.set(this.form.id, 0); store.testCaseMap.set(this.form.id, 0);
} }
}, },
activated() { activated() {
//
this.loadTestCase(); this.loadTestCase();
}, },
created(){ created(){
@ -727,19 +728,21 @@ export default {
setIsLastedVersion(isLastedVersion) { setIsLastedVersion(isLastedVersion) {
this.isLastedVersion = isLastedVersion; this.isLastedVersion = isLastedVersion;
}, },
loadTestCase() { async loadTestCase() {
// ID
this.checkCurrentProject();
let initFuc = this.initEdit; let initFuc = this.initEdit;
this.loading = true; this.loading = true;
getTestTemplate().then((template) => {
// ID
await this.checkCurrentProject();
getTestTemplate(this.projectId).then((template) => {
this.testCaseTemplate = template; this.testCaseTemplate = template;
store.testCaseTemplate = this.testCaseTemplate; store.testCaseTemplate = this.testCaseTemplate;
initFuc(); initFuc();
}); });
getProjectApplicationConfig('CASE_CUSTOM_NUM') getProjectApplicationConfig('CASE_CUSTOM_NUM', this.projectId)
.then(result => { .then(result => {
let data = result.data; let data = result.data;
if (data && data.typeValue === 'true') { if (data && data.typeValue === 'true') {
@ -776,7 +779,8 @@ export default {
} }
} }
}); });
getProjectApplicationConfig("CASE_PUBLIC").then((res) => {
getProjectApplicationConfig("CASE_PUBLIC", this.projectId).then((res) => {
let data = res.data; let data = res.data;
if (data && data.typeValue === "true") { if (data && data.typeValue === "true") {
this.isPublic = true; this.isPublic = true;
@ -784,6 +788,7 @@ export default {
this.isPublic = false; this.isPublic = false;
} }
}); });
if (hasLicense()) { if (hasLicense()) {
this.isXpack = true; this.isXpack = true;
} else { } else {
@ -965,23 +970,32 @@ export default {
callback(); callback();
} }
}, },
checkCurrentProject() { async checkCurrentProject() {
if (this.projectId) { if (this.isPublicShow) {
// projectId //
if (getCurrentProjectID() !== this.projectId) { await getSimpleTestCase(this.caseId).then((response) => {
setCurrentProjectID(this.projectId); let testCase = response.data;
location.reload(); this.projectId = testCase.projectId;
} });
} else { } else {
if (this.caseId) { this.projectId = this.routeProjectId;
getSimpleTestCase(this.caseId).then((response) => { if (this.routeProjectId) {
let testCase = response.data; // projectId
if (getCurrentProjectID() !== testCase.projectId) { if (getCurrentProjectID() !== this.projectId) {
// setCurrentProjectID(this.projectId);
setCurrentProjectID(testCase.projectId); location.reload();
location.reload(); }
} } else {
}) if (this.caseId) {
await getSimpleTestCase(this.caseId).then((response) => {
let testCase = response.data;
if (getCurrentProjectID() !== testCase.projectId) {
//
setCurrentProjectID(testCase.projectId);
location.reload();
}
})
}
} }
} }
}, },
@ -1500,7 +1514,7 @@ export default {
}, },
setLatest(version) { setLatest(version) {
let param = { let param = {
projectId: getCurrentProjectID(), projectId: this.projectId,
type: "TEST_CASE", type: "TEST_CASE",
versionId: version.id, versionId: version.id,
resourceId: this.caseId, resourceId: this.caseId,

View File

@ -8,8 +8,14 @@
class="case-desc-drawer-layout" class="case-desc-drawer-layout"
> >
<div style="height: 100%; overflow: auto"> <div style="height: 100%; overflow: auto">
<test-case-edit :is-public-show="true" :public-case-id.sync="publicCaseId" @close="close" @previousCase="previous" @nextCase="next" <test-case-edit :is-public-show="true"
:is-first-public.sync="isFirstPublic" :is-last-public.sync="isLastPublic"/> :public-case-id.sync="publicCaseId"
:is-first-public.sync="isFirstPublic"
:is-last-public.sync="isLastPublic"
@close="close"
@previousCase="previous"
@nextCase="next"
ref="testCaseEdit"/>
</div> </div>
</el-drawer> </el-drawer>
</template> </template>
@ -62,6 +68,10 @@ export default {
open(caseId) { open(caseId) {
this.visible = true; this.visible = true;
this.publicCaseId = caseId; this.publicCaseId = caseId;
//
this.$nextTick(() => {
this.$refs.testCaseEdit.loadTestCase();
});
}, },
close() { close() {
this.visible = false; this.visible = false;