From 73742e9e020d926fa68873a3385ab5ef81f40a30 Mon Sep 17 00:00:00 2001 From: Feroze Mohideen Date: Wed, 20 Sep 2023 13:28:32 -0400 Subject: [PATCH] filter out pre-deploy logs from 'all' logs view (#3597) --- .../app-dashboard/app-view/tabs/LogsTab.tsx | 1 + .../validate-apply/logs/Logs.tsx | 21 ++++++++-------- .../validate-apply/logs/utils.ts | 25 +++++++++++++++++-- 3 files changed, 35 insertions(+), 12 deletions(-) diff --git a/dashboard/src/main/home/app-dashboard/app-view/tabs/LogsTab.tsx b/dashboard/src/main/home/app-dashboard/app-view/tabs/LogsTab.tsx index 9cca803d1d..bea5a6ec2d 100644 --- a/dashboard/src/main/home/app-dashboard/app-view/tabs/LogsTab.tsx +++ b/dashboard/src/main/home/app-dashboard/app-view/tabs/LogsTab.tsx @@ -15,6 +15,7 @@ const LogsTab: React.FC = () => { appName={appName} serviceNames={serviceNames} deploymentTargetId={deploymentTargetId} + filterPredeploy={true} /> ); }; diff --git a/dashboard/src/main/home/app-dashboard/validate-apply/logs/Logs.tsx b/dashboard/src/main/home/app-dashboard/validate-apply/logs/Logs.tsx index ec522ff4ea..85fea490e1 100644 --- a/dashboard/src/main/home/app-dashboard/validate-apply/logs/Logs.tsx +++ b/dashboard/src/main/home/app-dashboard/validate-apply/logs/Logs.tsx @@ -25,10 +25,8 @@ import Container from "components/porter/Container"; import Button from "components/porter/Button"; import LogFilterContainer from "../../expanded-app/logs/LogFilterContainer"; import StyledLogs from "../../expanded-app/logs/StyledLogs"; -import { AppRevision } from "lib/revisions/types"; import { useLatestRevisionNumber, useRevisionIdToNumber } from "lib/hooks/useRevisionList"; import { useLocation } from "react-router"; -import { valueExists } from "shared/util"; type Props = { projectId: number; @@ -38,6 +36,7 @@ type Props = { deploymentTargetId: string; appRevisionId?: string; logFilterNames?: LogFilterName[]; + filterPredeploy?: boolean; }; const Logs: React.FC = ({ @@ -48,6 +47,7 @@ const Logs: React.FC = ({ deploymentTargetId, appRevisionId, logFilterNames = ["service_name", "revision", "output_stream"], + filterPredeploy = false, }) => { const { search } = useLocation(); const queryParams = new URLSearchParams(search); @@ -173,20 +173,21 @@ const Logs: React.FC = ({ }, 5000); }; - const { logs, refresh, moveCursor, paginationInfo } = useLogs( - projectId, - clusterId, + const { logs, refresh, moveCursor, paginationInfo } = useLogs({ + projectID: projectId, + clusterID: clusterId, selectedFilterValues, appName, - selectedFilterValues.service_name, + serviceName: selectedFilterValues.service_name, deploymentTargetId, - enteredSearchText, + searchParam: enteredSearchText, notify, - setIsLoading, + setLoading: setIsLoading, revisionIdToNumber, - selectedDate, + setDate: selectedDate, appRevisionId, - ); + filterPredeploy, + }); useEffect(() => { setFilters([ diff --git a/dashboard/src/main/home/app-dashboard/validate-apply/logs/utils.ts b/dashboard/src/main/home/app-dashboard/validate-apply/logs/utils.ts index 4822c9afee..df4e846398 100644 --- a/dashboard/src/main/home/app-dashboard/validate-apply/logs/utils.ts +++ b/dashboard/src/main/home/app-dashboard/validate-apply/logs/utils.ts @@ -41,7 +41,22 @@ export const parseLogs = (logs: any[] = []): PorterLog[] => { }); }; -export const useLogs = ( +export const useLogs = ({ + projectID, + clusterID, + selectedFilterValues, + appName, + serviceName, + deploymentTargetId, + searchParam, + notify, + setLoading, + revisionIdToNumber, + setDate, + appRevisionId = "", + timeRange, + filterPredeploy, +}: { projectID: number, clusterID: number, selectedFilterValues: Record, @@ -54,11 +69,13 @@ export const useLogs = ( revisionIdToNumber: Record, // if setDate is set, results are not live setDate?: Date, - appRevisionId: string = "", + appRevisionId?: string, timeRange?: { startTime?: Dayjs, endTime?: Dayjs, }, + filterPredeploy: boolean, +} ) => { const isLive = !setDate; const logsBufferRef = useRef([]); @@ -218,6 +235,10 @@ export const useLogs = ( return false; } + if (filterPredeploy && (log.metadata.raw_labels?.porter_run_service_name ?? "").endsWith("predeploy")) { + return false; + } + if (selectedFilterValues.revision !== GenericLogFilter.getDefaultOption("revision").value && log.metadata.revision !== selectedFilterValues.revision) { return false;