From 07771a6b4da01f15b0ddf035c4186c2851cfb3f8 Mon Sep 17 00:00:00 2001 From: lmalkam Date: Wed, 15 Jan 2025 12:38:11 +0530 Subject: [PATCH] feat:make asyncapi start studio consistent --- src/commands/start/studio.ts | 26 ++++++++++++++++++++++---- src/core/flags/start/studio.flags.ts | 1 - 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/src/commands/start/studio.ts b/src/commands/start/studio.ts index 23bc3e42e28..122a8d8d4be 100644 --- a/src/commands/start/studio.ts +++ b/src/commands/start/studio.ts @@ -2,18 +2,36 @@ import Command from '../../core/base'; import { start as startStudio } from '../../core/models/Studio'; import { load } from '../../core/models/SpecificationFile'; import { studioFlags } from '../../core/flags/start/studio.flags'; +import { Args } from '@oclif/core'; +import { ValidationError } from '../../core/errors/validation-error'; export default class StartStudio extends Command { static description = 'starts a new local instance of Studio'; static flags = studioFlags(); + static readonly args = { + 'spec-file': Args.string({ + description: 'spec path, url, or context-name', + required: true, + }), + }; + async run() { - const { flags } = await this.parse(StartStudio); - const filePath = flags.file || (await load()).getFilePath(); + const { args, flags } = await this.parse(StartStudio); + const filePath = args['spec-file']; const port = flags.port; - - this.specFile = await load(filePath); + + try { + this.specFile = await load(filePath); + } catch (err) { + this.error( + new ValidationError({ + type: 'invalid-file', + filepath: filePath, + }), + ); + } this.metricsMetadata.port = port; startStudio(filePath as string, port); diff --git a/src/core/flags/start/studio.flags.ts b/src/core/flags/start/studio.flags.ts index acc4a175713..008907f7994 100644 --- a/src/core/flags/start/studio.flags.ts +++ b/src/core/flags/start/studio.flags.ts @@ -3,7 +3,6 @@ import { Flags } from '@oclif/core'; export const studioFlags = () => { return { help: Flags.help({ char: 'h' }), - file: Flags.string({ char: 'f', description: 'path to the AsyncAPI file to link with Studio' }), port: Flags.integer({ char: 'p', description: 'port in which to start Studio' }), }; };