Skip to content

Commit

Permalink
Merge branch 'main' of github.com:grafana/k6-studio into feat/crash-r…
Browse files Browse the repository at this point in the history
…eporter
  • Loading branch information
cristianoventura committed Dec 30, 2024
2 parents 93f2055 + 1c2d87d commit 11996a9
Show file tree
Hide file tree
Showing 73 changed files with 681 additions and 222 deletions.
23 changes: 16 additions & 7 deletions .eslintrc.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ module.exports = {
extends: [
'eslint:recommended',
'plugin:@typescript-eslint/eslint-recommended',
'plugin:@typescript-eslint/recommended',
'plugin:@typescript-eslint/recommended-type-checked',
'plugin:import/recommended',
'plugin:import/electron',
'plugin:import/typescript',
Expand All @@ -18,7 +18,11 @@ module.exports = {
'prettier',
],
parser: '@typescript-eslint/parser',
ignorePatterns: ['resources/group_snippet.js', 'install-k6.js'],
ignorePatterns: [
'resources/group_snippet.js',
'install-k6.js',
'.eslintrc.cjs',
],
plugins: [
'import',
'unused-imports',
Expand All @@ -43,11 +47,16 @@ module.exports = {
argsIgnorePattern: '^_',
},
],
// TODO: remove warnings when plugin:@typescript-eslint/recommended-type-checked is enabled
'@typescript-eslint/no-unsafe-assignment': 'warn',
'@typescript-eslint/no-unsafe-return': 'warn',
'@typescript-eslint/no-unsafe-argument': 'warn',
'@typescript-eslint/no-unsafe-member-access': 'warn',
'@typescript-eslint/no-floating-promises': [
'error',
{
ignoreIIFE: true,
},
],
'@typescript-eslint/no-misused-promises': [
'error',
{ checksVoidReturn: false },
],
},

parserOptions: {
Expand Down
6 changes: 3 additions & 3 deletions package-lock.json

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

3 changes: 1 addition & 2 deletions src/ErrorElement.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,10 @@ import { css } from '@emotion/react'
import GrotCrashed from '@/assets/grot-crashed.svg'
import { ArrowLeftIcon } from '@radix-ui/react-icons'

const handleCreateIssue = () => {
const handleCreateIssue = () =>
window.studio.browser.openExternalLink(
'https://github.com/grafana/k6-studio/issues'
)
}

const handleOpenLogs = () => {
window.studio.log.openLogFolder()
Expand Down
2 changes: 1 addition & 1 deletion src/browser.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ export const launchBrowser = async (
`--proxy-server=http://localhost:${appSettings.proxy.port}`,
`--ignore-certificate-errors-spki-list=${certificateSPKI}`,
disableChromeOptimizations,
url ?? '',
url?.trim() || 'about:blank',
],
onExit: sendBrowserClosedEvent,
})
Expand Down
2 changes: 1 addition & 1 deletion src/codegen/codegen.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ describe('Code generation', () => {
generateScript({
recording: [],
generator: {
version: '0',
version: '1.0',
recordingPath: 'test',
options: {
loadProfile: {
Expand Down
2 changes: 2 additions & 0 deletions src/codegen/codegen.utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ export function stringify(value: unknown): string {
return `{${properties}}`
}

// TODO: https://github.com/grafana/k6-studio/issues/277
// eslint-disable-next-line @typescript-eslint/restrict-template-expressions
return `${value}`
}

Expand Down
2 changes: 1 addition & 1 deletion src/components/Collapsible.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ const Header = styled.div`
const CaretIcon = styled(CaretRightIcon)`
transform: rotate(0deg);
[data-state='open'] & {
button[data-state='open'] & {
transform: rotate(90deg);
}
`
Expand Down
3 changes: 1 addition & 2 deletions src/components/ExperimentalBanner.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
import { ExclamationTriangleIcon } from '@radix-ui/react-icons'
import { Flex, Text, Link } from '@radix-ui/themes'

const handleLinkClick = () => {
const handleLinkClick = () =>
window.studio.browser.openExternalLink(
'https://github.com/grafana/k6-studio/issues'
)
}

export function ExperimentalBanner() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/Form/FileUploadInput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@ export const FileUploadInput = ({
disabled={disabled}
onChange={field.onChange}
name={field.name}
// TODO: https://github.com/grafana/k6-studio/issues/277
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
value={field.value}
/>
</FieldGroup>
Expand Down
6 changes: 2 additions & 4 deletions src/components/Layout/ActivityBar/HelpButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,15 @@ import { QuestionMarkCircledIcon } from '@radix-ui/react-icons'
import { DropdownMenu, IconButton, Tooltip } from '@radix-ui/themes'

export function HelpButton() {
const handleOpenDocs = () => {
const handleOpenDocs = () =>
window.studio.browser.openExternalLink(
'https://grafana.com/docs/k6-studio/'
)
}

const handleReportIssue = () => {
const handleReportIssue = () =>
window.studio.browser.openExternalLink(
'https://github.com/grafana/k6-studio/issues'
)
}

const handleOpenApplicationLogs = () => {
window.studio.log.openLogFolder()
Expand Down
5 changes: 2 additions & 3 deletions src/components/Layout/ActivityBar/ProxyStatusIndicator.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,10 @@ export function ProxyStatusIndicator() {
const setProxyStatus = useStudioUIStore((state) => state.setProxyStatus)

useEffect(() => {
async function fetchProxyStatus() {
;(async function fetchProxyStatus() {
const status = await window.studio.proxy.getProxyStatus()
setProxyStatus(status)
}
fetchProxyStatus()
})()

return window.studio.proxy.onProxyStatusChange((status) =>
setProxyStatus(status)
Expand Down
5 changes: 3 additions & 2 deletions src/components/Layout/Sidebar/Sidebar.hooks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,13 +26,14 @@ function useFolderContent() {
const setFolderContent = useStudioUIStore((s) => s.setFolderContent)

useEffect(() => {
window.studio.ui.getFiles().then((files) => {
;(async () => {
const files = await window.studio.ui.getFiles()
setFolderContent({
recordings: toFileMap(files.recordings),
generators: toFileMap(files.generators),
scripts: toFileMap(files.scripts),
})
})
})()
}, [setFolderContent])

useEffect(
Expand Down
129 changes: 66 additions & 63 deletions src/components/Layout/Sidebar/Sidebar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,78 +28,81 @@ export function Sidebar({ isExpanded, onCollapseSidebar }: SidebarProps) {
maxWidth="100%"
overflow="hidden"
position="relative"
asChild
>
<Flex align="center" m="2" gap="2">
<SearchField
css={css`
flex: 1 1 0;
`}
filter={searchTerm}
placeholder="Find files..."
size="1"
onChange={setSearchTerm}
/>

{isExpanded && (
<IconButton
<Flex direction="column">
<Flex align="center" m="2" gap="2">
<SearchField
css={css`
flex: 1 1 0;
`}
filter={searchTerm}
placeholder="Find files..."
size="1"
variant="ghost"
color="gray"
onClick={onCollapseSidebar}
>
<PinLeftIcon />
</IconButton>
)}
</Flex>
<ScrollArea scrollbars="vertical">
<Flex direction="column" gap="2">
<FileTree
label="Recordings"
files={recordings}
noFilesMessage="No recordings found"
actions={
<>
<Tooltip content="New recording" side="right">
onChange={setSearchTerm}
/>

{isExpanded && (
<IconButton
size="1"
variant="ghost"
color="gray"
onClick={onCollapseSidebar}
>
<PinLeftIcon />
</IconButton>
)}
</Flex>
<ScrollArea scrollbars="vertical">
<Flex direction="column" gap="2" pb="2">
<FileTree
label="Recordings"
files={recordings}
noFilesMessage="No recordings found"
actions={
<>
<Tooltip content="New recording" side="right">
<IconButton
asChild
aria-label="New recording"
variant="ghost"
size="1"
>
<Link to={getRoutePath('recorder')}>
<PlusIcon />
</Link>
</IconButton>
</Tooltip>
</>
}
/>
<FileTree
label="Test generators"
files={generators}
noFilesMessage="No generators found"
actions={
<Tooltip content="New generator" side="right">
<IconButton
asChild
aria-label="New recording"
aria-label="New generator"
variant="ghost"
size="1"
onClick={createNewGenerator}
css={{ cursor: 'pointer' }}
>
<Link to={getRoutePath('recorder')}>
<PlusIcon />
</Link>
<PlusIcon />
</IconButton>
</Tooltip>
</>
}
/>
<FileTree
label="Test generators"
files={generators}
noFilesMessage="No generators found"
actions={
<Tooltip content="New generator" side="right">
<IconButton
asChild
aria-label="New generator"
variant="ghost"
size="1"
onClick={createNewGenerator}
css={{ cursor: 'pointer' }}
>
<PlusIcon />
</IconButton>
</Tooltip>
}
/>
<FileTree
label="Scripts"
files={scripts}
noFilesMessage="No scripts found"
/>
</Flex>
</ScrollArea>
}
/>
<FileTree
label="Scripts"
files={scripts}
noFilesMessage="No scripts found"
/>
</Flex>
</ScrollArea>
</Flex>
</Box>
)
}
14 changes: 6 additions & 8 deletions src/components/Settings/LogsSettings.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,11 @@ export function LogsSettings() {

// retrieve the current content of the log file
useEffect(() => {
async function fetchLogContent() {
;(async function fetchLogContent() {
const content = await window.studio.log.getLogContent()
setLogContent(content)
scrollToLastLine()
}

fetchLogContent()
})()
}, [scrollToLastLine])

// subscribe to log changes
Expand All @@ -45,14 +43,14 @@ export function LogsSettings() {
return (
<SettingsSection>
<Flex mb="4" justify="between" align="center">
<Flex>
<Flex align="center">
<Spinner mr="2" />
<Text size="2">
k6 Studio logs in this screen are updated in real-time.
<Text size="2" color="gray">
Application logs are updated in real-time.
</Text>
</Flex>
<Button onClick={handleOpenLogClick} variant="outline">
Open log location
Open logs folder
</Button>
</Flex>

Expand Down
26 changes: 26 additions & 0 deletions src/components/Settings/Settings.hooks.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { queryClient } from '@/utils/query'
import { useMutation, useQuery } from '@tanstack/react-query'

export function useSettings() {
return useQuery({
queryKey: ['settings'],
queryFn: window.studio.settings.getSettings,
})
}

export function useSaveSettings(onSuccess?: () => void) {
return useMutation({
mutationFn: window.studio.settings.saveSettings,
onSuccess: async (isSuccessful) => {
if (!isSuccessful) {
return
}

await queryClient.invalidateQueries({ queryKey: ['settings'] })
onSuccess?.()
},
onError: (error) => {
console.error('Error saving settings', error)
},
})
}
Loading

0 comments on commit 11996a9

Please sign in to comment.