getClassList.test.js 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. import resolveConfig from '../src/public/resolve-config'
  2. import { createContext } from '../src/lib/setupContextUtils'
  3. it('should generate every possible class, without variants', () => {
  4. let config = {}
  5. let context = createContext(resolveConfig(config))
  6. let classes = context.getClassList()
  7. expect(classes).toBeInstanceOf(Array)
  8. // Verify we have a `container` for the 'components' section.
  9. expect(classes).toContain('container')
  10. // Verify we handle the DEFAULT case correctly
  11. expect(classes).toContain('border')
  12. // Verify we handle negative values correctly
  13. expect(classes).toContain('-inset-1/4')
  14. expect(classes).toContain('-m-0')
  15. expect(classes).not.toContain('-uppercase')
  16. expect(classes).not.toContain('-opacity-50')
  17. config = { theme: { extend: { margin: { DEFAULT: '5px' } } } }
  18. context = createContext(resolveConfig(config))
  19. classes = context.getClassList()
  20. expect(classes).not.toContain('-m-DEFAULT')
  21. })
  22. it('should generate every possible class while handling negatives and prefixes', () => {
  23. let config = { prefix: 'tw-' }
  24. let context = createContext(resolveConfig(config))
  25. let classes = context.getClassList()
  26. expect(classes).toBeInstanceOf(Array)
  27. // Verify we have a `container` for the 'components' section.
  28. expect(classes).toContain('tw-container')
  29. // Verify we handle the DEFAULT case correctly
  30. expect(classes).toContain('tw-border')
  31. // Verify we handle negative values correctly
  32. expect(classes).toContain('-tw-inset-1/4')
  33. expect(classes).toContain('-tw-m-0')
  34. expect(classes).not.toContain('-tw-uppercase')
  35. expect(classes).not.toContain('-tw-opacity-50')
  36. // These utilities do work but there's no reason to generate
  37. // them alongside the `-{prefix}-{utility}` versions
  38. expect(classes).not.toContain('tw--inset-1/4')
  39. expect(classes).not.toContain('tw--m-0')
  40. config = {
  41. prefix: 'tw-',
  42. theme: { extend: { margin: { DEFAULT: '5px' } } },
  43. }
  44. context = createContext(resolveConfig(config))
  45. classes = context.getClassList()
  46. expect(classes).not.toContain('-tw-m-DEFAULT')
  47. })
  48. it('should not generate utilities with opacity by default', () => {
  49. let config = {}
  50. let context = createContext(resolveConfig(config))
  51. let classes = context.getClassList()
  52. expect(classes).not.toContain('bg-red-500/50')
  53. })
  54. it('should not generate utilities with opacity even if safe-listed', () => {
  55. let config = {
  56. safelist: [
  57. {
  58. pattern: /^bg-red-(400|500)(\/(40|50))?$/,
  59. },
  60. ],
  61. }
  62. let context = createContext(resolveConfig(config))
  63. let classes = context.getClassList()
  64. expect(classes).not.toContain('bg-red-500/50')
  65. })