测试用例只读页面

This commit is contained in:
chenjianxing 2020-06-02 11:39:56 +08:00
parent db9d5643aa
commit c9ceaa3c8c
4 changed files with 32 additions and 10 deletions

View File

@ -1,22 +1,22 @@
<template> <template>
<el-row type="flex" justify="start" :gutter="20" class="status-button"> <el-row type="flex" justify="start" :gutter="20" class="status-button">
<el-col> <el-col>
<el-button type="success" round size="mini" <el-button :disabled="isReadOnly" type="success" round size="mini"
:icon="status == 'Pass' ? 'el-icon-check' : ''" :icon="status == 'Pass' ? 'el-icon-check' : ''"
@click="setStatus('Pass')"> {{$t('test_track.plan_view.pass')}}</el-button> @click="setStatus('Pass')"> {{$t('test_track.plan_view.pass')}}</el-button>
</el-col> </el-col>
<el-col> <el-col>
<el-button type="danger" round size="mini" <el-button :disabled="isReadOnly" type="danger" round size="mini"
:icon="status == 'Failure' ? 'el-icon-check' : ''" :icon="status == 'Failure' ? 'el-icon-check' : ''"
@click="setStatus('Failure')"> {{$t('test_track.plan_view.failure')}}</el-button> @click="setStatus('Failure')"> {{$t('test_track.plan_view.failure')}}</el-button>
</el-col> </el-col>
<el-col> <el-col>
<el-button type="warning" round size="mini" <el-button :disabled="isReadOnly" type="warning" round size="mini"
:icon="status == 'Blocking' ? 'el-icon-check' : ''" :icon="status == 'Blocking' ? 'el-icon-check' : ''"
@click="setStatus('Blocking')"> {{$t('test_track.plan_view.blocking')}}</el-button> @click="setStatus('Blocking')"> {{$t('test_track.plan_view.blocking')}}</el-button>
</el-col> </el-col>
<el-col> <el-col>
<el-button type="info" round size="mini" <el-button :disabled="isReadOnly" type="info" round size="mini"
:icon="status == 'Skip' ? 'el-icon-check' : ''" :icon="status == 'Skip' ? 'el-icon-check' : ''"
@click="setStatus('Skip')"> {{$t('test_track.plan_view.skip')}}</el-button> @click="setStatus('Skip')"> {{$t('test_track.plan_view.skip')}}</el-button>
</el-col> </el-col>
@ -29,6 +29,10 @@
props: { props: {
status: { status: {
type: String type: String
},
isReadOnly: {
type: Boolean,
default: false
} }
}, },
methods: { methods: {

View File

@ -41,7 +41,7 @@
@click="handleNext()"/> @click="handleNext()"/>
<el-divider direction="vertical"></el-divider> <el-divider direction="vertical"></el-divider>
<el-button type="primary" size="mini" @click="saveCase()">{{$t('test_track.save')}}</el-button> <el-button type="primary" size="mini" :disabled="isReadOnly" @click="saveCase()">{{$t('test_track.save')}}</el-button>
</el-col> </el-col>
</el-row> </el-row>
@ -69,6 +69,7 @@
<el-col :span="13"> <el-col :span="13">
<test-plan-test-case-status-button class="status-button" <test-plan-test-case-status-button class="status-button"
@statusChange="statusChange" @statusChange="statusChange"
:is-read-only="isReadOnly"
:status="testCase.status"/> :status="testCase.status"/>
</el-col> </el-col>
</el-row> </el-row>
@ -130,6 +131,7 @@
type="textarea" type="textarea"
:autosize="{ minRows: 2, maxRows: 4}" :autosize="{ minRows: 2, maxRows: 4}"
:rows="2" :rows="2"
:disabled="isReadOnly"
v-model="scope.row.actualResult" v-model="scope.row.actualResult"
:placeholder="$t('commons.input_content')" :placeholder="$t('commons.input_content')"
clearable></el-input> clearable></el-input>
@ -139,6 +141,7 @@
<el-table-column :label="$t('test_track.plan_view.step_result')" min-width="9%"> <el-table-column :label="$t('test_track.plan_view.step_result')" min-width="9%">
<template v-slot:default="scope"> <template v-slot:default="scope">
<el-select <el-select
:disabled="isReadOnly"
v-model="scope.row.executeResult" v-model="scope.row.executeResult"
size="mini"> size="mini">
<el-option :label="$t('test_track.plan_view.pass')" value="Pass" style="color: #7ebf50;"></el-option> <el-option :label="$t('test_track.plan_view.pass')" value="Pass" style="color: #7ebf50;"></el-option>
@ -155,6 +158,7 @@
<el-row v-if="testCase.issues"> <el-row v-if="testCase.issues">
<el-col :span="5" :offset="1"> <el-col :span="5" :offset="1">
<el-switch <el-switch
:disabled="isReadOnly"
v-model="testCase.issues.hasIssues" v-model="testCase.issues.hasIssues"
@change="issuesChange" @change="issuesChange"
:active-text="$t('test_track.plan_view.submit_issues')"> :active-text="$t('test_track.plan_view.submit_issues')">
@ -164,7 +168,7 @@
<el-row v-if="testCase.issues && testCase.issues.hasIssues"> <el-row v-if="testCase.issues && testCase.issues.hasIssues">
<el-col :span="20" :offset="1" class="step-edit"> <el-col :span="20" :offset="1" class="step-edit">
<ckeditor :editor="editor" v-model="testCase.issues.content"/> <ckeditor :editor="editor" :disabled="isReadOnly" :config="editorConfig" v-model="testCase.issues.content"/>
</el-col> </el-col>
</el-row> </el-row>
@ -220,6 +224,10 @@
index: 0, index: 0,
testCases: [], testCases: [],
editor: ClassicEditor, editor: ClassicEditor,
editorConfig: {
// 'increaseIndent','decreaseIndent'
toolbar: [ 'heading', '|', 'bold', 'italic', 'link', 'bulletedList', 'numberedList', 'blockQuote' ,'insertTable', '|','undo', 'redo'],
},
test: {}, test: {},
activeTab: 'detail' activeTab: 'detail'
}; };
@ -230,6 +238,10 @@
}, },
searchParam: { searchParam: {
type: Object type: Object
},
isReadOnly: {
type: Boolean,
default: false
} }
}, },
methods: { methods: {
@ -334,10 +346,8 @@
}, },
testTabChange(data) { testTabChange(data) {
if (this.testCase.type == 'performance' && data.paneName == 'result') { if (this.testCase.type == 'performance' && data.paneName == 'result') {
console.log(data);
this.$refs.performanceTestResult.checkReportStatus(); this.$refs.performanceTestResult.checkReportStatus();
} }
// console.log(data);
}, },
saveReport(reportId) { saveReport(reportId) {
this.$post('/test/plan/case/edit', {id: this.testCase.id, reportId: reportId}); this.$post('/test/plan/case/edit', {id: this.testCase.id, reportId: reportId});

View File

@ -28,6 +28,7 @@
@sort-change="sort" @sort-change="sort"
@select="handleSelectionChange" @select="handleSelectionChange"
row-key="id" row-key="id"
@row-click="showDetail"
:data="tableData"> :data="tableData">
<el-table-column <el-table-column
@ -134,6 +135,7 @@
ref="testPlanTestCaseEdit" ref="testPlanTestCaseEdit"
:search-param="condition" :search-param="condition"
@refresh="initTableData" @refresh="initTableData"
:is-read-only="isReadOnly"
@refreshTable="search"/> @refreshTable="search"/>
<test-report-template-list @openReport="openReport" :plan-id="planId" ref="testReporTtemplateList"/> <test-report-template-list @openReport="openReport" :plan-id="planId" ref="testReporTtemplateList"/>
@ -188,6 +190,7 @@
total: 0, total: 0,
selectIds: new Set(), selectIds: new Set(),
testPlan: {}, testPlan: {},
isReadOnly: false,
priorityFilters: [ priorityFilters: [
{text: 'P0', value: 'P0'}, {text: 'P0', value: 'P0'},
{text: 'P1', value: 'P1'}, {text: 'P1', value: 'P1'},
@ -247,6 +250,10 @@
}); });
} }
}, },
showDetail(row, event, column) {
this.isReadOnly = true;
this.$refs.testPlanTestCaseEdit.openTestCaseEdit(row);
},
refresh() { refresh() {
this.condition = {}; this.condition = {};
this.selectIds.clear(); this.selectIds.clear();
@ -271,6 +278,7 @@
return path + "/" + this.currentPage + "/" + this.pageSize; return path + "/" + this.currentPage + "/" + this.pageSize;
}, },
handleEdit(testCase, index) { handleEdit(testCase, index) {
this.isReadOnly = false;
this.$refs.testPlanTestCaseEdit.openTestCaseEdit(testCase); this.$refs.testPlanTestCaseEdit.openTestCaseEdit(testCase);
}, },
handleDelete(testCase) { handleDelete(testCase) {
@ -390,7 +398,7 @@
width: 240px; width: 240px;
} }
.test-case-status { .test-case-status,.el-table {
cursor:pointer; cursor:pointer;
} }

View File

@ -28,7 +28,7 @@
editor: ClassicEditor, editor: ClassicEditor,
// editorData: '<p>Content of the editor.</p>', // editorData: '<p>Content of the editor.</p>',
editorConfig: { editorConfig: {
// The configuration of the editor. toolbar: [ 'heading', '|', 'bold', 'italic', 'link', 'bulletedList', 'numberedList', 'blockQuote' ,'insertTable', '|','undo', 'redo']
} }
} }
}, },