123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { nextTick } from 'vue'
- import { renderComponent } from '#tests/support/components/index.ts'
- import { useApplicationStore } from '#shared/stores/application.ts'
- import CommonDateTime, { type Props } from '../CommonDateTime.vue'
- vi.hoisted(() => {
- vi.useFakeTimers().setSystemTime(new Date('2020-10-11T10:10:10Z'))
- })
- const dateTime = '2020-10-10T10:10:10Z'
- const renderDateTime = (props: Props, slots = {}) => {
- return renderComponent(CommonDateTime, {
- props: {
- ...props,
- },
- slots,
- store: true,
- })
- }
- describe('CommonDateTime.vue', () => {
- it('renders with type relative', async () => {
- const view = renderDateTime({ dateTime, type: 'relative' })
- expect(view.container).toHaveTextContent('1 day ago')
- })
- it('renders with prefix', async () => {
- const view = renderDateTime(
- { dateTime, type: 'relative' },
- { prefix: 'prefix-slot' },
- )
- expect(view.container).toHaveTextContent('prefix-slot 1 day ago')
- })
- it('renders with type absolute + absolute format "datetime" (default)', async () => {
- const view = renderDateTime({
- dateTime,
- type: 'absolute',
- })
- expect(view.container).toHaveTextContent('2020-10-10 10:10')
- })
- it('renders with type absolute + absolute format "datetime" (set via prop)', async () => {
- const view = renderDateTime({
- dateTime,
- type: 'absolute',
- absoluteFormat: 'datetime',
- })
- expect(view.container).toHaveTextContent('2020-10-10 10:10')
- })
- it('renders with type absolute + absolute format "date"', async () => {
- const view = renderDateTime({
- dateTime,
- type: 'absolute',
- absoluteFormat: 'date',
- })
- expect(view.container).toHaveTextContent('2020-10-10')
- })
- it('renders with type absolute (application store)', async () => {
- const view = renderDateTime({ dateTime, type: 'absolute' })
- useApplicationStore().config.pretty_date_format = 'absolute'
- await nextTick()
- expect(view.container).toHaveTextContent('2020-10-10')
- })
- it('renders with type configured + absolute format "date" (application store)', async () => {
- const view = renderDateTime({ dateTime, type: 'configured' })
- useApplicationStore().config.pretty_date_format = 'absolute'
- await nextTick()
- expect(view.container).toHaveTextContent('2020-10-10')
- })
- it('renders with type timestamp (application store)', async () => {
- const view = renderDateTime({ dateTime, type: 'configured' })
- useApplicationStore().config.pretty_date_format = 'timestamp'
- await nextTick()
- expect(view.container).toHaveTextContent('2020-10-10 10:10')
- })
- it('renders with type relative (application store)', async () => {
- const view = renderDateTime({ dateTime, type: 'configured' })
- useApplicationStore().config.pretty_date_format = 'relative'
- await nextTick()
- expect(view.container).toHaveTextContent('1 day ago')
- })
- })
|