Settings.test.tsx 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. import React from 'react'
  2. import { render, screen, fireEvent, waitFor } from '@testing-library/react'
  3. import { QueryClient, QueryClientProvider } from '@tanstack/react-query'
  4. import Settings from '../src/pages/Settings/Settings'
  5. // Mock Taro
  6. jest.mock('@tarojs/taro', () => ({
  7. showToast: jest.fn(),
  8. showModal: jest.fn(({ success }) => success?.({ confirm: true })),
  9. removeStorageSync: jest.fn(),
  10. reLaunch: jest.fn()
  11. }))
  12. // Mock auth hook
  13. jest.mock('@d8d/mini-enterprise-auth-ui/hooks', () => ({
  14. useAuth: jest.fn(() => ({
  15. user: {
  16. id: 1,
  17. username: 'testuser',
  18. nickname: '测试企业',
  19. company: {
  20. id: 1,
  21. companyName: '阿里巴巴集团',
  22. contactPerson: '张三',
  23. contactPhone: '13800138000',
  24. status: 1,
  25. createTime: '2023-01-01',
  26. updateTime: '2023-01-01'
  27. }
  28. },
  29. logout: jest.fn()
  30. }))
  31. }))
  32. // Mock API client
  33. jest.mock('../src/api/companyClient', () => ({
  34. enterpriseCompanyClient: {
  35. overview: {
  36. $get: jest.fn()
  37. }
  38. }
  39. }))
  40. // Mock layouts
  41. jest.mock('@d8d/yongren-shared-ui/components/YongrenTabBarLayout', () => ({
  42. YongrenTabBarLayout: ({ children, activeKey }: any) => (
  43. <div data-testid="tab-bar-layout" data-active-key={activeKey}>
  44. {children}
  45. </div>
  46. )
  47. }))
  48. jest.mock('@d8d/mini-shared-ui-components/components/navbar', () => ({
  49. Navbar: ({ title }: any) => <div data-testid="navbar">{title}</div>
  50. }))
  51. const { enterpriseCompanyClient } = require('../../api/companyClient')
  52. const { useAuth } = require('@d8d/mini-enterprise-auth-ui/hooks')
  53. const Taro = require('@tarojs/taro')
  54. const createTestQueryClient = () => new QueryClient({
  55. defaultOptions: {
  56. queries: { retry: false },
  57. mutations: { retry: false }
  58. }
  59. })
  60. const renderWithQueryClient = (component: React.ReactElement) => {
  61. const queryClient = createTestQueryClient()
  62. return render(
  63. <QueryClientProvider client={queryClient}>
  64. {component}
  65. </QueryClientProvider>
  66. )
  67. }
  68. describe('Settings', () => {
  69. beforeEach(() => {
  70. jest.clearAllMocks()
  71. })
  72. describe('企业信息展示', () => {
  73. it('应该显示加载状态', () => {
  74. enterpriseCompanyClient.overview.$get.mockImplementation(
  75. () => new Promise(() => {})
  76. )
  77. renderWithQueryClient(<Settings />)
  78. expect(screen.getByText('加载中...')).toBeInTheDocument()
  79. })
  80. it('应该成功加载并显示企业信息', async () => {
  81. const mockOverview = {
  82. '在职人员数': 24,
  83. '进行中订单数': 3,
  84. '已完成订单数': 9,
  85. '累计订单数': 12
  86. }
  87. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  88. ok: true,
  89. json: async () => mockOverview
  90. })
  91. renderWithQueryClient(<Settings />)
  92. await waitFor(() => {
  93. expect(screen.getByText('阿里巴巴集团')).toBeInTheDocument()
  94. expect(screen.getByText('24')).toBeInTheDocument()
  95. expect(screen.getByText('3')).toBeInTheDocument()
  96. expect(screen.getByText('12')).toBeInTheDocument()
  97. expect(screen.getByText('在职人员')).toBeInTheDocument()
  98. expect(screen.getByText('进行中订单')).toBeInTheDocument()
  99. expect(screen.getByText('累计订单')).toBeInTheDocument()
  100. })
  101. })
  102. it('应该显示企业账号标识', async () => {
  103. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  104. ok: true,
  105. json: async () => ({})
  106. })
  107. renderWithQueryClient(<Settings />)
  108. await waitFor(() => {
  109. expect(screen.getByText('企业账号')).toBeInTheDocument()
  110. })
  111. })
  112. })
  113. describe('功能列表', () => {
  114. beforeEach(async () => {
  115. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  116. ok: true,
  117. json: async () => ({})
  118. })
  119. })
  120. it('应该显示所有功能项', async () => {
  121. renderWithQueryClient(<Settings />)
  122. await waitFor(() => {
  123. expect(screen.getByText('账号信息')).toBeInTheDocument()
  124. expect(screen.getByText('安全设置')).toBeInTheDocument()
  125. expect(screen.getByText('消息通知')).toBeInTheDocument()
  126. expect(screen.getByText('帮助中心')).toBeInTheDocument()
  127. expect(screen.getByText('用户协议')).toBeInTheDocument()
  128. expect(screen.getByText('隐私政策')).toBeInTheDocument()
  129. expect(screen.getByText('退出登录')).toBeInTheDocument()
  130. })
  131. })
  132. it('应该显示延期功能的标识', async () => {
  133. renderWithQueryClient(<Settings />)
  134. await waitFor(() => {
  135. const deferredLabels = screen.getAllByText('(后期优化)')
  136. expect(deferredLabels.length).toBeGreaterThan(0)
  137. })
  138. })
  139. })
  140. describe('延期功能处理', () => {
  141. beforeEach(async () => {
  142. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  143. ok: true,
  144. json: async () => ({})
  145. })
  146. })
  147. it('点击延期功能应该显示提示', async () => {
  148. renderWithQueryClient(<Settings />)
  149. await waitFor(() => {
  150. expect(screen.getByText('账号信息')).toBeInTheDocument()
  151. })
  152. fireEvent.click(screen.getByText('账号信息'))
  153. expect(Taro.showModal).toHaveBeenCalledWith(
  154. expect.objectContaining({
  155. title: '功能开发中',
  156. content: expect.stringContaining('账号信息功能正在开发中')
  157. })
  158. )
  159. })
  160. it('点击安全设置应该显示提示', async () => {
  161. renderWithQueryClient(<Settings />)
  162. await waitFor(() => {
  163. expect(screen.getByText('安全设置')).toBeInTheDocument()
  164. })
  165. fireEvent.click(screen.getByText('安全设置'))
  166. expect(Taro.showModal).toHaveBeenCalledWith(
  167. expect.objectContaining({
  168. title: '功能开发中',
  169. content: expect.stringContaining('安全设置功能正在开发中')
  170. })
  171. )
  172. })
  173. it('点击消息通知应该显示提示', async () => {
  174. renderWithQueryClient(<Settings />)
  175. await waitFor(() => {
  176. expect(screen.getByText('消息通知')).toBeInTheDocument()
  177. })
  178. fireEvent.click(screen.getByText('消息通知'))
  179. expect(Taro.showModal).toHaveBeenCalledWith(
  180. expect.objectContaining({
  181. title: '功能开发中',
  182. content: expect.stringContaining('消息通知功能正在开发中')
  183. })
  184. )
  185. })
  186. })
  187. describe('退出登录', () => {
  188. beforeEach(async () => {
  189. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  190. ok: true,
  191. json: async () => ({})
  192. })
  193. })
  194. it('点击退出登录应该显示确认对话框', async () => {
  195. renderWithQueryClient(<Settings />)
  196. await waitFor(() => {
  197. expect(screen.getByText('退出登录')).toBeInTheDocument()
  198. })
  199. fireEvent.click(screen.getByText('退出登录'))
  200. expect(Taro.showModal).toHaveBeenCalledWith(
  201. expect.objectContaining({
  202. title: '退出登录',
  203. content: '确定要退出登录吗?'
  204. })
  205. )
  206. })
  207. it('确认退出登录应该清除认证信息并跳转', async () => {
  208. renderWithQueryClient(<Settings />)
  209. await waitFor(() => {
  210. expect(screen.getByText('退出登录')).toBeInTheDocument()
  211. })
  212. fireEvent.click(screen.getByText('退出登录'))
  213. await waitFor(() => {
  214. expect(Taro.removeStorageSync).toHaveBeenCalledWith('enterpriseToken')
  215. expect(Taro.removeStorageSync).toHaveBeenCalledWith('enterpriseUser')
  216. expect(Taro.reLaunch).toHaveBeenCalledWith({
  217. url: '/pages/login/index'
  218. })
  219. })
  220. })
  221. })
  222. describe('其他功能', () => {
  223. beforeEach(async () => {
  224. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  225. ok: true,
  226. json: async () => ({})
  227. })
  228. })
  229. it('点击帮助中心应该显示提示', async () => {
  230. renderWithQueryClient(<Settings />)
  231. await waitFor(() => {
  232. expect(screen.getByText('帮助中心')).toBeInTheDocument()
  233. })
  234. fireEvent.click(screen.getByText('帮助中心'))
  235. expect(Taro.showToast).toHaveBeenCalledWith(
  236. expect.objectContaining({ title: '即将开放' })
  237. )
  238. })
  239. it('点击用户协议应该显示提示', async () => {
  240. renderWithQueryClient(<Settings />)
  241. await waitFor(() => {
  242. expect(screen.getByText('用户协议')).toBeInTheDocument()
  243. })
  244. fireEvent.click(screen.getByText('用户协议'))
  245. expect(Taro.showToast).toHaveBeenCalledWith(
  246. expect.objectContaining({ title: '即将开放' })
  247. )
  248. })
  249. it('点击隐私政策应该显示提示', async () => {
  250. renderWithQueryClient(<Settings />)
  251. await waitFor(() => {
  252. expect(screen.getByText('隐私政策')).toBeInTheDocument()
  253. })
  254. fireEvent.click(screen.getByText('隐私政策'))
  255. expect(Taro.showToast).toHaveBeenCalledWith(
  256. expect.objectContaining({ title: '即将开放' })
  257. )
  258. })
  259. })
  260. describe('组件集成', () => {
  261. it('应该正确集成Navbar组件', async () => {
  262. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  263. ok: true,
  264. json: async () => ({})
  265. })
  266. renderWithQueryClient(<Settings />)
  267. await waitFor(() => {
  268. const navbar = screen.getByTestId('navbar')
  269. expect(navbar).toBeInTheDocument()
  270. expect(navbar).toHaveTextContent('企业设置')
  271. })
  272. })
  273. it('应该正确集成TabBarLayout并激活settings标签', async () => {
  274. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  275. ok: true,
  276. json: async () => ({})
  277. })
  278. renderWithQueryClient(<Settings />)
  279. await waitFor(() => {
  280. const layout = screen.getByTestId('tab-bar-layout')
  281. expect(layout).toHaveAttribute('data-active-key', 'settings')
  282. })
  283. })
  284. it('应该正确集成useAuth hook', async () => {
  285. enterpriseCompanyClient.overview.$get.mockResolvedValue({
  286. ok: true,
  287. json: async () => ({})
  288. })
  289. renderWithQueryClient(<Settings />)
  290. await waitFor(() => {
  291. expect(useAuth).toHaveBeenCalled()
  292. expect(screen.getByText('阿里巴巴集团')).toBeInTheDocument()
  293. })
  294. })
  295. })
  296. })