mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-02-01 20:23:36 +00:00
fix(tests): Update provider-factory tests for CursorProvider
- Update test assertions from expecting 1 provider to 2 - Add CursorProvider import and tests for Cursor model routing - Add tests for Cursor models (cursor-auto, cursor-sonnet-4.5, etc.) - Update tests for gpt-5.2/grok/gemini-3-pro as valid Cursor models - Add tests for checkAllProviders to expect cursor status - Add tests for getProviderByName with 'cursor' 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
||||
import { ProviderFactory } from '@/providers/provider-factory.js';
|
||||
import { ClaudeProvider } from '@/providers/claude-provider.js';
|
||||
import { CursorProvider } from '@/providers/cursor-provider.js';
|
||||
|
||||
describe('provider-factory.ts', () => {
|
||||
let consoleSpy: any;
|
||||
@@ -65,39 +66,65 @@ describe('provider-factory.ts', () => {
|
||||
});
|
||||
});
|
||||
|
||||
describe('Cursor models (cursor-* prefix)', () => {
|
||||
it('should return CursorProvider for cursor-auto', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('cursor-auto');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should return CursorProvider for cursor-sonnet-4.5', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('cursor-sonnet-4.5');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should return CursorProvider for cursor-gpt-5.2', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('cursor-gpt-5.2');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should be case-insensitive for cursor models', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('CURSOR-AUTO');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should return CursorProvider for known cursor model ID without prefix', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('auto');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Unknown models', () => {
|
||||
it('should default to ClaudeProvider for unknown model', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('unknown-model-123');
|
||||
expect(provider).toBeInstanceOf(ClaudeProvider);
|
||||
});
|
||||
|
||||
it('should warn when defaulting to Claude', () => {
|
||||
ProviderFactory.getProviderForModel('random-model');
|
||||
expect(consoleSpy.warn).toHaveBeenCalledWith(
|
||||
expect.stringContaining('Unknown model prefix')
|
||||
);
|
||||
expect(consoleSpy.warn).toHaveBeenCalledWith(expect.stringContaining('random-model'));
|
||||
expect(consoleSpy.warn).toHaveBeenCalledWith(
|
||||
expect.stringContaining('defaulting to Claude')
|
||||
);
|
||||
});
|
||||
|
||||
it('should handle empty string', () => {
|
||||
it('should handle empty string by defaulting to ClaudeProvider', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('');
|
||||
expect(provider).toBeInstanceOf(ClaudeProvider);
|
||||
expect(consoleSpy.warn).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('should default to ClaudeProvider for gpt models (not supported)', () => {
|
||||
it('should default to ClaudeProvider for completely unknown prefixes', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('random-xyz-model');
|
||||
expect(provider).toBeInstanceOf(ClaudeProvider);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Cursor models via model ID lookup', () => {
|
||||
it('should return CursorProvider for gpt-5.2 (valid Cursor model)', () => {
|
||||
// gpt-5.2 is in CURSOR_MODEL_MAP
|
||||
const provider = ProviderFactory.getProviderForModel('gpt-5.2');
|
||||
expect(provider).toBeInstanceOf(ClaudeProvider);
|
||||
expect(consoleSpy.warn).toHaveBeenCalled();
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should default to ClaudeProvider for o-series models (not supported)', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('o1');
|
||||
expect(provider).toBeInstanceOf(ClaudeProvider);
|
||||
expect(consoleSpy.warn).toHaveBeenCalled();
|
||||
it('should return CursorProvider for grok (valid Cursor model)', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('grok');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should return CursorProvider for gemini-3-pro (valid Cursor model)', () => {
|
||||
const provider = ProviderFactory.getProviderForModel('gemini-3-pro');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
});
|
||||
});
|
||||
@@ -114,9 +141,15 @@ describe('provider-factory.ts', () => {
|
||||
expect(hasClaudeProvider).toBe(true);
|
||||
});
|
||||
|
||||
it('should return exactly 1 provider', () => {
|
||||
it('should return exactly 2 providers', () => {
|
||||
const providers = ProviderFactory.getAllProviders();
|
||||
expect(providers).toHaveLength(1);
|
||||
expect(providers).toHaveLength(2);
|
||||
});
|
||||
|
||||
it('should include CursorProvider', () => {
|
||||
const providers = ProviderFactory.getAllProviders();
|
||||
const hasCursorProvider = providers.some((p) => p instanceof CursorProvider);
|
||||
expect(hasCursorProvider).toBe(true);
|
||||
});
|
||||
|
||||
it('should create new instances each time', () => {
|
||||
@@ -145,7 +178,14 @@ describe('provider-factory.ts', () => {
|
||||
const keys = Object.keys(statuses);
|
||||
|
||||
expect(keys).toContain('claude');
|
||||
expect(keys).toHaveLength(1);
|
||||
expect(keys).toContain('cursor');
|
||||
expect(keys).toHaveLength(2);
|
||||
});
|
||||
|
||||
it('should include cursor status', async () => {
|
||||
const statuses = await ProviderFactory.checkAllProviders();
|
||||
|
||||
expect(statuses.cursor).toHaveProperty('installed');
|
||||
});
|
||||
});
|
||||
|
||||
@@ -160,12 +200,19 @@ describe('provider-factory.ts', () => {
|
||||
expect(provider).toBeInstanceOf(ClaudeProvider);
|
||||
});
|
||||
|
||||
it("should return CursorProvider for 'cursor'", () => {
|
||||
const provider = ProviderFactory.getProviderByName('cursor');
|
||||
expect(provider).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should be case-insensitive', () => {
|
||||
const provider1 = ProviderFactory.getProviderByName('CLAUDE');
|
||||
const provider2 = ProviderFactory.getProviderByName('ANTHROPIC');
|
||||
const provider3 = ProviderFactory.getProviderByName('CURSOR');
|
||||
|
||||
expect(provider1).toBeInstanceOf(ClaudeProvider);
|
||||
expect(provider2).toBeInstanceOf(ClaudeProvider);
|
||||
expect(provider3).toBeInstanceOf(CursorProvider);
|
||||
});
|
||||
|
||||
it('should return null for unknown provider', () => {
|
||||
@@ -218,5 +265,14 @@ describe('provider-factory.ts', () => {
|
||||
|
||||
expect(hasClaudeModels).toBe(true);
|
||||
});
|
||||
|
||||
it('should include Cursor models', () => {
|
||||
const models = ProviderFactory.getAllAvailableModels();
|
||||
|
||||
// Cursor models should include cursor provider
|
||||
const hasCursorModels = models.some((m) => m.provider === 'cursor');
|
||||
|
||||
expect(hasCursorModels).toBe(true);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user