Skip to content

Commit

Permalink
Merge branch 'main' of https://github.com/risingwavelabs/risingwave i…
Browse files Browse the repository at this point in the history
…nto li0k/storage_ctl_cancel_task
  • Loading branch information
Li0k committed Jan 5, 2024
2 parents 510f5ba + 788d6cd commit 38fa535
Show file tree
Hide file tree
Showing 98 changed files with 2,633 additions and 1,224 deletions.
18 changes: 10 additions & 8 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion ci/scripts/e2e-sink-test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ sqllogictest -p 4566 -d dev './e2e_test/sink/append_only_sink.slt'
sqllogictest -p 4566 -d dev './e2e_test/sink/create_sink_as.slt'
sqllogictest -p 4566 -d dev './e2e_test/sink/blackhole_sink.slt'
sqllogictest -p 4566 -d dev './e2e_test/sink/remote/types.slt'
sqllogictest -p 4566 -d dev './e2e_test/sink/sink_into_table.slt'
sqllogictest -p 4566 -d dev './e2e_test/sink/sink_into_table/*.slt'
sleep 1

echo "--- testing remote sinks"
Expand Down
13 changes: 3 additions & 10 deletions dashboard/components/BackPressureTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,11 @@ import {
Th,
Thead,
Tr,
useToast,
} from "@chakra-ui/react"
import { sortBy } from "lodash"
import Head from "next/head"
import { Fragment, useEffect, useState } from "react"
import useErrorToast from "../hook/useErrorToast"
import { getActorBackPressures } from "../pages/api/metric"
import RateBar from "./RateBar"
import { Metrics } from "./metrics"
Expand All @@ -44,7 +44,7 @@ export default function BackPressureTable({
}) {
const [backPressuresMetrics, setBackPressuresMetrics] =
useState<BackPressuresMetrics>()
const toast = useToast()
const toast = useErrorToast()

useEffect(() => {
async function doFetch() {
Expand All @@ -58,14 +58,7 @@ export default function BackPressureTable({
setBackPressuresMetrics(metrics)
await new Promise((resolve) => setTimeout(resolve, 5000)) // refresh every 5 secs
} catch (e: any) {
toast({
title: "Error Occurred",
description: e.toString(),
status: "error",
duration: 5000,
isClosable: true,
})
console.error(e)
toast(e, "warning")
break
}
}
Expand Down
4 changes: 2 additions & 2 deletions dashboard/components/FragmentGraph.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import {
generateBoxLinks,
layout,
} from "../lib/layout"
import { PlanNodeDatum } from "../pages/streaming_plan"
import { PlanNodeDatum } from "../pages/fragment_graph"
import BackPressureTable from "./BackPressureTable"

const ReactJson = loadable(() => import("react-json-view"))
Expand Down Expand Up @@ -218,7 +218,7 @@ export default function FragmentGraph({

text
.attr("fill", "black")
.text(({ id }) => `Fragment #${id}`)
.text(({ id }) => `Fragment ${id}`)
.attr("font-family", "inherit")
.attr("text-anchor", "end")
.attr("dy", ({ height }) => height - actorMarginY + 12)
Expand Down
68 changes: 44 additions & 24 deletions dashboard/components/Layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ import { UrlObject } from "url"
import {
IconArrowRightCircle,
IconArrowRightCircleFill,
IconBoxArrowUpRight,
IconServer,
} from "../components/utils/icons"

Expand All @@ -41,11 +42,13 @@ function NavButton({
children,
leftIcon,
leftIconActive,
external,
}: {
href: string | UrlObject
children?: React.ReactNode
leftIcon?: React.ReactElement
leftIconActive?: React.ReactElement
external?: boolean
}) {
const router = useRouter()
const [match, setMatch] = useState(false)
Expand All @@ -55,19 +58,22 @@ function NavButton({
return () => {}
}, [href, router.asPath])

const icon =
leftIcon || (external ? <IconBoxArrowUpRight /> : <IconArrowRightCircle />)
const activeIcon =
leftIconActive ||
leftIcon ||
(external ? undefined : <IconArrowRightCircleFill />)

return (
<Link href={href}>
<Link href={href} target={external ? "_blank" : undefined}>
<Button
colorScheme={match ? "blue" : "gray"}
color={match ? "blue.600" : "gray.500"}
variant={match ? "outline" : "ghost"}
width="full"
justifyContent="flex-start"
leftIcon={
match
? leftIconActive || leftIcon || <IconArrowRightCircleFill />
: leftIcon || <IconArrowRightCircle />
}
leftIcon={match ? activeIcon : icon}
>
{children}
</Button>
Expand All @@ -83,6 +89,14 @@ function NavTitle({ children }: { children: React.ReactNode }) {
)
}

function Section({ children }: { children: React.ReactNode }) {
return (
<VStack width="full" alignItems="flex-start" px={3}>
{children}
</VStack>
)
}

function Layout({ children }: { children: React.ReactNode }) {
return (
<Flex>
Expand Down Expand Up @@ -110,10 +124,12 @@ function Layout({ children }: { children: React.ReactNode }) {
</Text>
</HStack>
</Box>
<NavButton href="/cluster/" leftIcon={<IconServer />}>
Cluster Overview
</NavButton>
<VStack width="full" alignItems="flex-start" px={3}>
<Section>
<NavButton href="/cluster/" leftIcon={<IconServer />}>
Cluster Overview
</NavButton>
</Section>
<Section>
<NavTitle>Catalog</NavTitle>
<NavButton href="/sources/">Sources</NavButton>
<NavButton href="/tables/">Tables</NavButton>
Expand All @@ -124,28 +140,32 @@ function Layout({ children }: { children: React.ReactNode }) {
<NavButton href="/internal_tables/">Internal Tables</NavButton>
<NavButton href="/sinks/">Sinks</NavButton>
<NavButton href="/views/">Views</NavButton>
</VStack>
<VStack width="full" alignItems="flex-start" px={3}>
</Section>
<Section>
<NavTitle>Streaming</NavTitle>
<NavButton href="/streaming_graph/">Graph</NavButton>
<NavButton href="/streaming_plan/">Fragments</NavButton>
</VStack>
<VStack width="full" alignItems="flex-start" px={3}>
<NavButton href="/dependency_graph/">Dependency Graph</NavButton>
<NavButton href="/fragment_graph/">Fragment Graph</NavButton>
</Section>
<Section>
<NavTitle>Batch</NavTitle>
<NavButton href="/batch_tasks/">Batch Tasks</NavButton>
</VStack>
<VStack width="full" alignItems="flex-start" px={3}>
</Section>
<Section>
<NavTitle>Explain</NavTitle>
<NavButton href="/explain_distsql/">Distributed Plan</NavButton>
</VStack>
<VStack width="full" alignItems="flex-start" px={3}>
</Section>
<Section>
<NavTitle>Debug</NavTitle>
<NavButton href="/await_tree/">Await Tree Dump</NavButton>
<NavButton href="/heap_profiling/">Heap Profiling</NavButton>
<NavButton href="/api/monitor/diagnose">Diagnose</NavButton>
</VStack>
<VStack mb={3}></VStack>
<NavButton href="/settings/">Settings</NavButton>
<NavButton href="/api/monitor/diagnose" external>
Diagnose
</NavButton>
</Section>
<Section>
<NavTitle>Settings</NavTitle>
<NavButton href="/settings/">Settings</NavButton>
</Section>
</VStack>
</Box>
<Box flex={1} overflowY="scroll">
Expand Down
13 changes: 3 additions & 10 deletions dashboard/components/Relations.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,14 +33,14 @@ import {
Thead,
Tr,
useDisclosure,
useToast,
} from "@chakra-ui/react"
import loadable from "@loadable/component"
import Head from "next/head"

import Link from "next/link"
import { Fragment, useEffect, useState } from "react"
import Title from "../components/Title"
import useErrorToast from "../hook/useErrorToast"
import extractColumnInfo from "../lib/extractInfo"
import { Relation, StreamingJob } from "../pages/api/streaming"
import {
Expand Down Expand Up @@ -121,22 +121,15 @@ export function Relations<R extends Relation>(
getRelations: () => Promise<R[]>,
extraColumns: Column<R>[]
) {
const toast = useToast()
const toast = useErrorToast()
const [relationList, setRelationList] = useState<R[]>([])

useEffect(() => {
async function doFetch() {
try {
setRelationList(await getRelations())
} catch (e: any) {
toast({
title: "Error Occurred",
description: e.toString(),
status: "error",
duration: 5000,
isClosable: true,
})
console.error(e)
toast(e)
}
}
doFetch()
Expand Down
4 changes: 4 additions & 0 deletions dashboard/components/utils/icons.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,3 +26,7 @@ export function IconArrowRightCircle() {
export function IconArrowRightCircleFill() {
return <i className="bi bi-arrow-right-circle-fill"></i>
}

export function IconBoxArrowUpRight() {
return <i className="bi bi-box-arrow-up-right"></i>
}
47 changes: 47 additions & 0 deletions dashboard/hook/useErrorToast.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
/*
* Copyright 2024 RisingWave Labs
*
* Licensed 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.
*/

import { AlertStatus, useToast } from "@chakra-ui/react"
import { useCallback } from "react"

export default function useErrorToast() {
const toast = useToast()

return useCallback(
(e: any, status: AlertStatus = "error") => {
let title: string
let description: string | undefined

if (e instanceof Error) {
title = e.message
description = e.cause?.toString()
} else {
title = e.toString()
}

toast({
title,
description,
status,
duration: 5000,
isClosable: true,
})

console.error(e)
},
[toast]
)
}
Loading

0 comments on commit 38fa535

Please sign in to comment.