parent
c8a08f1115
commit
c3cb192486
100
web/containers/ModelLabel/ModelLabel.test.tsx
Normal file
100
web/containers/ModelLabel/ModelLabel.test.tsx
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
import React from 'react'
|
||||||
|
import { render, waitFor, screen } from '@testing-library/react'
|
||||||
|
import { useAtomValue } from 'jotai'
|
||||||
|
import { useActiveModel } from '@/hooks/useActiveModel'
|
||||||
|
import { useSettings } from '@/hooks/useSettings'
|
||||||
|
import ModelLabel from '@/containers/ModelLabel'
|
||||||
|
|
||||||
|
jest.mock('jotai', () => ({
|
||||||
|
useAtomValue: jest.fn(),
|
||||||
|
atom: jest.fn(),
|
||||||
|
}))
|
||||||
|
|
||||||
|
jest.mock('@/hooks/useActiveModel', () => ({
|
||||||
|
useActiveModel: jest.fn(),
|
||||||
|
}))
|
||||||
|
|
||||||
|
jest.mock('@/hooks/useSettings', () => ({
|
||||||
|
useSettings: jest.fn(),
|
||||||
|
}))
|
||||||
|
|
||||||
|
describe('ModelLabel', () => {
|
||||||
|
const mockUseAtomValue = useAtomValue as jest.Mock
|
||||||
|
const mockUseActiveModel = useActiveModel as jest.Mock
|
||||||
|
const mockUseSettings = useSettings as jest.Mock
|
||||||
|
|
||||||
|
const defaultProps: any = {
|
||||||
|
metadata: {
|
||||||
|
author: 'John Doe', // Add the 'author' property with a value
|
||||||
|
tags: ['8B'],
|
||||||
|
size: 100,
|
||||||
|
},
|
||||||
|
compact: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
jest.clearAllMocks()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('renders NotEnoughMemoryLabel when minimumRamModel is greater than totalRam', async () => {
|
||||||
|
mockUseAtomValue
|
||||||
|
.mockReturnValueOnce(0)
|
||||||
|
.mockReturnValueOnce(0)
|
||||||
|
.mockReturnValueOnce(0)
|
||||||
|
mockUseActiveModel.mockReturnValue({
|
||||||
|
activeModel: { metadata: { size: 0 } },
|
||||||
|
})
|
||||||
|
mockUseSettings.mockReturnValue({ settings: { run_mode: 'cpu' } })
|
||||||
|
|
||||||
|
render(<ModelLabel {...defaultProps} />)
|
||||||
|
await waitFor(() => {
|
||||||
|
expect(screen.getByText('Not enough RAM')).toBeDefined()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('renders SlowOnYourDeviceLabel when minimumRamModel is less than totalRam but greater than availableRam', async () => {
|
||||||
|
mockUseAtomValue
|
||||||
|
.mockReturnValueOnce(100)
|
||||||
|
.mockReturnValueOnce(50)
|
||||||
|
.mockReturnValueOnce(10)
|
||||||
|
mockUseActiveModel.mockReturnValue({
|
||||||
|
activeModel: { metadata: { size: 0 } },
|
||||||
|
})
|
||||||
|
mockUseSettings.mockReturnValue({ settings: { run_mode: 'cpu' } })
|
||||||
|
|
||||||
|
const props = {
|
||||||
|
...defaultProps,
|
||||||
|
metadata: {
|
||||||
|
...defaultProps.metadata,
|
||||||
|
size: 50,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
render(<ModelLabel {...props} />)
|
||||||
|
await waitFor(() => {
|
||||||
|
expect(screen.getByText('Slow on your device')).toBeDefined()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('renders nothing when minimumRamModel is less than availableRam', () => {
|
||||||
|
mockUseAtomValue
|
||||||
|
.mockReturnValueOnce(100)
|
||||||
|
.mockReturnValueOnce(50)
|
||||||
|
.mockReturnValueOnce(0)
|
||||||
|
mockUseActiveModel.mockReturnValue({
|
||||||
|
activeModel: { metadata: { size: 0 } },
|
||||||
|
})
|
||||||
|
mockUseSettings.mockReturnValue({ settings: { run_mode: 'cpu' } })
|
||||||
|
|
||||||
|
const props = {
|
||||||
|
...defaultProps,
|
||||||
|
metadata: {
|
||||||
|
...defaultProps.metadata,
|
||||||
|
size: 10,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
const { container } = render(<ModelLabel {...props} />)
|
||||||
|
expect(container.firstChild).toBeNull()
|
||||||
|
})
|
||||||
|
})
|
||||||
@ -10,8 +10,6 @@ import { useSettings } from '@/hooks/useSettings'
|
|||||||
|
|
||||||
import NotEnoughMemoryLabel from './NotEnoughMemoryLabel'
|
import NotEnoughMemoryLabel from './NotEnoughMemoryLabel'
|
||||||
|
|
||||||
import RecommendedLabel from './RecommendedLabel'
|
|
||||||
|
|
||||||
import SlowOnYourDeviceLabel from './SlowOnYourDeviceLabel'
|
import SlowOnYourDeviceLabel from './SlowOnYourDeviceLabel'
|
||||||
|
|
||||||
import {
|
import {
|
||||||
@ -53,9 +51,7 @@ const ModelLabel = ({ metadata, compact }: Props) => {
|
|||||||
/>
|
/>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
if (minimumRamModel < availableRam && !compact) {
|
|
||||||
return <RecommendedLabel />
|
|
||||||
}
|
|
||||||
if (minimumRamModel < totalRam && minimumRamModel > availableRam) {
|
if (minimumRamModel < totalRam && minimumRamModel > availableRam) {
|
||||||
return <SlowOnYourDeviceLabel compact={compact} />
|
return <SlowOnYourDeviceLabel compact={compact} />
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user