mirror of
https://github.com/movie-web/providers.git
synced 2025-09-13 15:33:26 +00:00
unit tests for provider checks, provider listings, utils and provider meta
This commit is contained in:
50
src/__test__/runner/meta.test.ts
Normal file
50
src/__test__/runner/meta.test.ts
Normal file
@@ -0,0 +1,50 @@
|
||||
import { mockEmbeds, mockSources } from '@/__test__/providerTests';
|
||||
import { makeProviders } from '@/main/builder';
|
||||
import { afterEach, describe, expect, it, vi } from 'vitest';
|
||||
|
||||
const mocks = await vi.hoisted(async () => (await import('@/__test__/providerTests')).makeProviderMocks());
|
||||
vi.mock('@/providers/all', () => mocks);
|
||||
|
||||
describe('ProviderControls.getMetadata()', () => {
|
||||
afterEach(() => {
|
||||
vi.clearAllMocks();
|
||||
});
|
||||
|
||||
it('should return null if not found', () => {
|
||||
mocks.gatherAllSources.mockReturnValue([]);
|
||||
mocks.gatherAllEmbeds.mockReturnValue([]);
|
||||
const p = makeProviders({
|
||||
fetcher: null as any,
|
||||
});
|
||||
expect(p.getMetadata(':)')).toEqual(null);
|
||||
});
|
||||
|
||||
it('should return correct source meta', () => {
|
||||
mocks.gatherAllSources.mockReturnValue([mockSources.fullSourceZBoth]);
|
||||
mocks.gatherAllEmbeds.mockReturnValue([]);
|
||||
const p = makeProviders({
|
||||
fetcher: null as any,
|
||||
});
|
||||
expect(p.getMetadata(mockSources.fullSourceZBoth.id)).toEqual({
|
||||
type: 'source',
|
||||
id: 'z',
|
||||
name: 'Z',
|
||||
rank: mockSources.fullSourceZBoth.rank,
|
||||
mediaTypes: ['movie', 'show'],
|
||||
});
|
||||
});
|
||||
|
||||
it('should return correct embed meta', () => {
|
||||
mocks.gatherAllSources.mockReturnValue([]);
|
||||
mocks.gatherAllEmbeds.mockReturnValue([mockEmbeds.fullEmbedX]);
|
||||
const p = makeProviders({
|
||||
fetcher: null as any,
|
||||
});
|
||||
expect(p.getMetadata(mockEmbeds.fullEmbedX.id)).toEqual({
|
||||
type: 'embed',
|
||||
id: 'x',
|
||||
name: 'X',
|
||||
rank: mockEmbeds.fullEmbedX.rank,
|
||||
});
|
||||
});
|
||||
});
|
Reference in New Issue
Block a user