mirror of
https://github.com/langgenius/dify.git
synced 2026-04-12 22:17:09 +08:00
Signed-off-by: edvatar <88481784+toroleapinc@users.noreply.github.com> Signed-off-by: -LAN- <laipz8200@outlook.com> Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: majiayu000 <1835304752@qq.com> Co-authored-by: Poojan <poojan@infocusp.com> Co-authored-by: sahil-infocusp <73810410+sahil-infocusp@users.noreply.github.com> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: Pandaaaa906 <ye.pandaaaa906@gmail.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: heyszt <270985384@qq.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Ijas <ijas.ahmd.ap@gmail.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: 木之本澪 <kinomotomiovo@gmail.com> Co-authored-by: KinomotoMio <200703522+KinomotoMio@users.noreply.github.com> Co-authored-by: 不做了睡大觉 <64798754+stakeswky@users.noreply.github.com> Co-authored-by: User <user@example.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: edvatar <88481784+toroleapinc@users.noreply.github.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: Leilei <138381132+Inlei@users.noreply.github.com> Co-authored-by: HaKu <104669497+haku-ink@users.noreply.github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: wangxiaolei <fatelei@gmail.com> Co-authored-by: Varun Chawla <34209028+veeceey@users.noreply.github.com> Co-authored-by: Stephen Zhou <38493346+hyoban@users.noreply.github.com> Co-authored-by: yyh <yuanyouhuilyz@gmail.com> Co-authored-by: yyh <92089059+lyzno1@users.noreply.github.com> Co-authored-by: tda <95275462+tda1017@users.noreply.github.com> Co-authored-by: root <root@DESKTOP-KQLO90N> Co-authored-by: Sisyphus <clio-agent@sisyphuslabs.ai> Co-authored-by: Niels Kaspers <153818647+nielskaspers@users.noreply.github.com> Co-authored-by: hj24 <mambahj24@gmail.com> Co-authored-by: Tyson Cung <45380903+tysoncung@users.noreply.github.com> Co-authored-by: Stephen Zhou <hi@hyoban.cc> Co-authored-by: FFXN <31929997+FFXN@users.noreply.github.com> Co-authored-by: slegarraga <64795732+slegarraga@users.noreply.github.com> Co-authored-by: 99 <wh2099@pm.me> Co-authored-by: Br1an <932039080@qq.com> Co-authored-by: L1nSn0w <l1nsn0w@qq.com> Co-authored-by: Yunlu Wen <yunlu.wen@dify.ai> Co-authored-by: akkoaya <151345394+akkoaya@users.noreply.github.com> Co-authored-by: 盐粒 Yanli <yanli@dify.ai> Co-authored-by: lif <1835304752@qq.com> Co-authored-by: weiguang li <codingpunk@gmail.com> Co-authored-by: Copilot <198982749+Copilot@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: HanWenbo <124024253+hwb96@users.noreply.github.com> Co-authored-by: Coding On Star <447357187@qq.com> Co-authored-by: CodingOnStar <hanxujiang@dify.com> Co-authored-by: Stable Genius <stablegenius043@gmail.com> Co-authored-by: Stable Genius <259448942+stablegenius49@users.noreply.github.com> Co-authored-by: ふるい <46769295+Echo0ff@users.noreply.github.com> Co-authored-by: Xiyuan Chen <52963600+GareArc@users.noreply.github.com>
87 lines
3.4 KiB
TypeScript
87 lines
3.4 KiB
TypeScript
import { render, screen } from '@testing-library/react'
|
|
import { Img } from '..'
|
|
|
|
describe('Img', () => {
|
|
describe('Rendering', () => {
|
|
it('should render with the correct wrapper class', () => {
|
|
const { container } = render(<Img src="https://example.com/image.png" />)
|
|
|
|
const wrapper = container.querySelector('.markdown-img-wrapper')
|
|
expect(wrapper).toBeInTheDocument()
|
|
})
|
|
|
|
it('should render ImageGallery with the src as an array', () => {
|
|
render(<Img src="https://example.com/image.png" />)
|
|
|
|
const gallery = screen.getByTestId('image-gallery')
|
|
expect(gallery).toBeInTheDocument()
|
|
|
|
const images = gallery.querySelectorAll('img')
|
|
expect(images).toHaveLength(1)
|
|
expect(images[0]).toHaveAttribute('src', 'https://example.com/image.png')
|
|
})
|
|
|
|
it('should pass src as single element array to ImageGallery', () => {
|
|
const testSrc = 'https://example.com/test-image.jpg'
|
|
render(<Img src={testSrc} />)
|
|
|
|
const gallery = screen.getByTestId('image-gallery')
|
|
const images = gallery.querySelectorAll('img')
|
|
|
|
expect(images[0]).toHaveAttribute('src', testSrc)
|
|
})
|
|
|
|
it('should render with different src values', () => {
|
|
const { rerender } = render(<Img src="https://example.com/first.png" />)
|
|
expect(screen.getByTestId('gallery-image')).toHaveAttribute('src', 'https://example.com/first.png')
|
|
|
|
rerender(<Img src="https://example.com/second.jpg" />)
|
|
expect(screen.getByTestId('gallery-image')).toHaveAttribute('src', 'https://example.com/second.jpg')
|
|
})
|
|
})
|
|
|
|
describe('Props', () => {
|
|
it('should accept src prop with various URL formats', () => {
|
|
// Test with HTTPS URL
|
|
const { container: container1 } = render(<Img src="https://example.com/image.png" />)
|
|
expect(container1.querySelector('.markdown-img-wrapper')).toBeInTheDocument()
|
|
|
|
// Test with HTTP URL
|
|
const { container: container2 } = render(<Img src="http://example.com/image.png" />)
|
|
expect(container2.querySelector('.markdown-img-wrapper')).toBeInTheDocument()
|
|
|
|
// Test with data URL
|
|
const { container: container3 } = render(<Img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mNk+M9QDwADhgGAWjR9awAAAABJRU5ErkJggg==" />)
|
|
expect(container3.querySelector('.markdown-img-wrapper')).toBeInTheDocument()
|
|
|
|
// Test with relative URL
|
|
const { container: container4 } = render(<Img src="/images/photo.jpg" />)
|
|
expect(container4.querySelector('.markdown-img-wrapper')).toBeInTheDocument()
|
|
})
|
|
|
|
it('should handle empty string src', () => {
|
|
const { container } = render(<Img src="" />)
|
|
|
|
const wrapper = container.querySelector('.markdown-img-wrapper')
|
|
expect(wrapper).toBeInTheDocument()
|
|
})
|
|
})
|
|
|
|
describe('Structure', () => {
|
|
it('should have exactly one wrapper div', () => {
|
|
const { container } = render(<Img src="https://example.com/image.png" />)
|
|
|
|
const wrappers = container.querySelectorAll('.markdown-img-wrapper')
|
|
expect(wrappers).toHaveLength(1)
|
|
})
|
|
|
|
it('should contain ImageGallery component inside wrapper', () => {
|
|
const { container } = render(<Img src="https://example.com/image.png" />)
|
|
|
|
const wrapper = container.querySelector('.markdown-img-wrapper')
|
|
const gallery = wrapper?.querySelector('[data-testid="image-gallery"]')
|
|
expect(gallery).toBeInTheDocument()
|
|
})
|
|
})
|
|
})
|