mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-17 17:45:03 +02:00
Show logs if step has error (#3979)
This commit is contained in:
parent
0a91e07397
commit
61f4c6a540
@ -191,6 +191,7 @@
|
|||||||
"pipelines_for_pr": "Pipelines for pull request #{index}",
|
"pipelines_for_pr": "Pipelines for pull request #{index}",
|
||||||
"exit_code": "Exit Code {exitCode}",
|
"exit_code": "Exit Code {exitCode}",
|
||||||
"loading": "Loading…",
|
"loading": "Loading…",
|
||||||
|
"no_logs": "No logs",
|
||||||
"pipeline": "Pipeline #{pipelineId}",
|
"pipeline": "Pipeline #{pipelineId}",
|
||||||
"log_title": "Step Logs",
|
"log_title": "Step Logs",
|
||||||
"log_download_error": "There was an error while downloading the log file",
|
"log_download_error": "There was an error while downloading the log file",
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
<div class="flex flex-row items-center ml-auto gap-x-2">
|
<div class="flex flex-row items-center ml-auto gap-x-2">
|
||||||
<IconButton
|
<IconButton
|
||||||
v-if="step?.end_time !== undefined"
|
v-if="step?.end_time !== undefined && hasLogs"
|
||||||
:is-loading="downloadInProgress"
|
:is-loading="downloadInProgress"
|
||||||
:title="$t('repo.pipeline.actions.log_download')"
|
:title="$t('repo.pipeline.actions.log_download')"
|
||||||
class="!hover:bg-white !hover:bg-opacity-10"
|
class="!hover:bg-white !hover:bg-opacity-10"
|
||||||
@ -45,7 +45,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div
|
<div
|
||||||
v-show="hasLogs && loadedLogs"
|
v-show="hasLogs && loadedLogs && (log?.length || 0) > 0"
|
||||||
ref="consoleElement"
|
ref="consoleElement"
|
||||||
class="w-full max-w-full grid grid-cols-[min-content,minmax(0,1fr),min-content] p-4 auto-rows-min flex-grow overflow-x-hidden overflow-y-auto text-xs md:text-sm"
|
class="w-full max-w-full grid grid-cols-[min-content,minmax(0,1fr),min-content] p-4 auto-rows-min flex-grow overflow-x-hidden overflow-y-auto text-xs md:text-sm"
|
||||||
>
|
>
|
||||||
@ -88,10 +88,10 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="m-auto text-xl text-wp-text-alt-100">
|
<div class="m-auto text-xl text-wp-text-alt-100">
|
||||||
<span v-if="step?.error">{{ step.error }}</span>
|
<span v-if="step?.state === 'skipped'">{{ $t('repo.pipeline.actions.canceled') }}</span>
|
||||||
<span v-else-if="step?.state === 'skipped'">{{ $t('repo.pipeline.actions.canceled') }}</span>
|
|
||||||
<span v-else-if="!step?.start_time">{{ $t('repo.pipeline.step_not_started') }}</span>
|
<span v-else-if="!step?.start_time">{{ $t('repo.pipeline.step_not_started') }}</span>
|
||||||
<div v-else-if="!loadedLogs">{{ $t('repo.pipeline.loading') }}</div>
|
<div v-else-if="!loadedLogs">{{ $t('repo.pipeline.loading') }}</div>
|
||||||
|
<div v-else-if="log?.length === 0">{{ $t('repo.pipeline.no_logs') }}</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div
|
<div
|
||||||
@ -99,7 +99,8 @@
|
|||||||
class="flex items-center w-full bg-wp-code-100 text-md text-wp-code-text-alt-100 p-4 font-bold"
|
class="flex items-center w-full bg-wp-code-100 text-md text-wp-code-text-alt-100 p-4 font-bold"
|
||||||
>
|
>
|
||||||
<PipelineStatusIcon :status="step.state" class="!h-4 !w-4" />
|
<PipelineStatusIcon :status="step.state" class="!h-4 !w-4" />
|
||||||
<span class="px-2">{{ $t('repo.pipeline.exit_code', { exitCode: step.exit_code }) }}</span>
|
<span v-if="step?.error" class="px-2">{{ step.error }}</span>
|
||||||
|
<span v-else class="px-2">{{ $t('repo.pipeline.exit_code', { exitCode: step.exit_code }) }}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -160,7 +161,7 @@ const loadedLogs = computed(() => !!log.value);
|
|||||||
const hasLogs = computed(
|
const hasLogs = computed(
|
||||||
() =>
|
() =>
|
||||||
// we do not have logs for skipped steps
|
// we do not have logs for skipped steps
|
||||||
repo?.value && pipeline.value && step.value && step.value.state !== 'skipped' && step.value.state !== 'killed',
|
repo?.value && pipeline.value && step.value && step.value.state !== 'skipped',
|
||||||
);
|
);
|
||||||
const autoScroll = useStorage('log-auto-scroll', false);
|
const autoScroll = useStorage('log-auto-scroll', false);
|
||||||
const showActions = ref(false);
|
const showActions = ref(false);
|
||||||
|
@ -8,17 +8,7 @@
|
|||||||
/>
|
/>
|
||||||
|
|
||||||
<div class="flex items-start justify-center flex-grow relative basis-full md:basis-auto">
|
<div class="flex items-start justify-center flex-grow relative basis-full md:basis-auto">
|
||||||
<Container v-if="selectedStep?.error" fill-width class="p-0">
|
<Container v-if="pipeline!.errors?.some((e) => !e.is_warning)" fill-width class="p-0">
|
||||||
<Panel>
|
|
||||||
<div class="flex flex-col items-center text-center gap-4">
|
|
||||||
<Icon name="status-error" class="w-16 h-16 text-wp-state-error-100" />
|
|
||||||
<span class="text-xl">{{ $t('repo.pipeline.we_got_some_errors') }}</span>
|
|
||||||
<span class="whitespace-pre-wrap">{{ selectedStep?.error }}</span>
|
|
||||||
</div>
|
|
||||||
</Panel>
|
|
||||||
</Container>
|
|
||||||
|
|
||||||
<Container v-else-if="pipeline!.errors?.some((e) => !e.is_warning)" fill-width class="p-0">
|
|
||||||
<Panel>
|
<Panel>
|
||||||
<div class="flex flex-col items-center text-center gap-4">
|
<div class="flex flex-col items-center text-center gap-4">
|
||||||
<Icon name="status-error" class="w-16 h-16 text-wp-state-error-100" />
|
<Icon name="status-error" class="w-16 h-16 text-wp-state-error-100" />
|
||||||
@ -86,7 +76,6 @@ import useApiClient from '~/compositions/useApiClient';
|
|||||||
import { useAsyncAction } from '~/compositions/useAsyncAction';
|
import { useAsyncAction } from '~/compositions/useAsyncAction';
|
||||||
import useNotifications from '~/compositions/useNotifications';
|
import useNotifications from '~/compositions/useNotifications';
|
||||||
import type { Pipeline, PipelineStep, Repo, RepoPermissions } from '~/lib/api/types';
|
import type { Pipeline, PipelineStep, Repo, RepoPermissions } from '~/lib/api/types';
|
||||||
import { findStep } from '~/utils/helpers';
|
|
||||||
|
|
||||||
const props = defineProps<{
|
const props = defineProps<{
|
||||||
stepId?: string | null;
|
stepId?: string | null;
|
||||||
@ -148,8 +137,6 @@ const selectedStepId = computed({
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const selectedStep = computed(() => findStep(pipeline.value.workflows || [], selectedStepId.value || -1));
|
|
||||||
|
|
||||||
const { doSubmit: approvePipeline, isLoading: isApprovingPipeline } = useAsyncAction(async () => {
|
const { doSubmit: approvePipeline, isLoading: isApprovingPipeline } = useAsyncAction(async () => {
|
||||||
if (!repo) {
|
if (!repo) {
|
||||||
throw new Error('Unexpected: Repo is undefined');
|
throw new Error('Unexpected: Repo is undefined');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user