mirror of
				https://gitee.com/vant-contrib/vant.git
				synced 2025-10-26 01:02:12 +08:00 
			
		
		
		
	test(Cascader): add test cases
This commit is contained in:
		
							parent
							
								
									f71a1da8a7
								
							
						
					
					
						commit
						5452701c47
					
				| @ -81,7 +81,7 @@ export default { | |||||||
| | Attribute | Description | Type | Default | | | Attribute | Description | Type | Default | | ||||||
| | --- | --- | --- | --- | | | --- | --- | --- | --- | | ||||||
| | title | Title | _string_ | - | | | title | Title | _string_ | - | | ||||||
| | value | Values of selected options | _string \| number_ | - | | | value | Value of selected option | _string \| number_ | - | | ||||||
| | options | Options | _Option[]_ | `[]` | | | options | Options | _Option[]_ | `[]` | | ||||||
| | placeholder | Placeholder of unselected tab | _string_ | `Select` | | | placeholder | Placeholder of unselected tab | _string_ | `Select` | | ||||||
| | active-color | Active color | _string_ | `#ee0a24` | | | active-color | Active color | _string_ | `#ee0a24` | | ||||||
|  | |||||||
							
								
								
									
										26
									
								
								src/cascader/test/__snapshots__/demo.spec.js.snap
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/cascader/test/__snapshots__/demo.spec.js.snap
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | |||||||
|  | // Jest Snapshot v1, https://goo.gl/fbAQLP | ||||||
|  | 
 | ||||||
|  | exports[`renders demo correctly 1`] = ` | ||||||
|  | <div> | ||||||
|  |   <div> | ||||||
|  |     <div role="button" tabindex="0" class="van-cell van-cell--clickable van-field"> | ||||||
|  |       <div class="van-cell__title van-field__label"><span>地区</span></div> | ||||||
|  |       <div class="van-cell__value van-field__value"> | ||||||
|  |         <div class="van-field__body"><input type="text" readonly="readonly" placeholder="请选择地区" class="van-field__control"></div> | ||||||
|  |       </div><i class="van-icon van-icon-arrow van-cell__right-icon"> | ||||||
|  |         <!----></i> | ||||||
|  |     </div> | ||||||
|  |     <!----> | ||||||
|  |   </div> | ||||||
|  |   <div> | ||||||
|  |     <div role="button" tabindex="0" class="van-cell van-cell--clickable van-field"> | ||||||
|  |       <div class="van-cell__title van-field__label"><span>地区</span></div> | ||||||
|  |       <div class="van-cell__value van-field__value"> | ||||||
|  |         <div class="van-field__body"><input type="text" readonly="readonly" placeholder="请选择地区" class="van-field__control"></div> | ||||||
|  |       </div><i class="van-icon van-icon-arrow van-cell__right-icon"> | ||||||
|  |         <!----></i> | ||||||
|  |     </div> | ||||||
|  |     <!----> | ||||||
|  |   </div> | ||||||
|  | </div> | ||||||
|  | `; | ||||||
							
								
								
									
										8
									
								
								src/cascader/test/__snapshots__/index.spec.js.snap
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/cascader/test/__snapshots__/index.spec.js.snap
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | // Jest Snapshot v1, https://goo.gl/fbAQLP | ||||||
|  | 
 | ||||||
|  | exports[`should render title slot correctly 1`] = `<h2 class="van-cascader__title">Custom Title</h2>`; | ||||||
|  | 
 | ||||||
|  | exports[`should select correct option when value changed 1`] = ` | ||||||
|  | <li class="van-cascader__option van-cascader__option--selected"><span>Ouhai</span><i class="van-icon van-icon-success van-cascader__selected-icon"> | ||||||
|  |     <!----></i></li> | ||||||
|  | `; | ||||||
							
								
								
									
										96
									
								
								src/cascader/test/index.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								src/cascader/test/index.spec.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,96 @@ | |||||||
|  | import Cascader from '..'; | ||||||
|  | import { mount, later } from '../../../test'; | ||||||
|  | import options from '../demo/area-en-US'; | ||||||
|  | 
 | ||||||
|  | test('should emit change event when active option changed', async () => { | ||||||
|  |   const wrapper = mount(Cascader, { | ||||||
|  |     propsData: { | ||||||
|  |       options, | ||||||
|  |     }, | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   await later(); | ||||||
|  |   wrapper.find('.van-cascader__option').trigger('click'); | ||||||
|  | 
 | ||||||
|  |   const firstOption = options[0]; | ||||||
|  |   expect(wrapper.emitted('change')[0]).toEqual([ | ||||||
|  |     { | ||||||
|  |       value: firstOption.value, | ||||||
|  |       tabIndex: 0, | ||||||
|  |       selectedOptions: [firstOption], | ||||||
|  |     }, | ||||||
|  |   ]); | ||||||
|  | 
 | ||||||
|  |   await later(); | ||||||
|  |   wrapper | ||||||
|  |     .findAll('.van-cascader__options') | ||||||
|  |     .at(1) | ||||||
|  |     .find('.van-cascader__option') | ||||||
|  |     .trigger('click'); | ||||||
|  |   const secondOption = options[0].children[0]; | ||||||
|  |   expect(wrapper.emitted('change')[1]).toEqual([ | ||||||
|  |     { | ||||||
|  |       value: secondOption.value, | ||||||
|  |       tabIndex: 1, | ||||||
|  |       selectedOptions: [firstOption, secondOption], | ||||||
|  |     }, | ||||||
|  |   ]); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | test('should emit finish event when all options is selected', async () => { | ||||||
|  |   const option = { value: '1', text: 'foo' }; | ||||||
|  |   const wrapper = mount(Cascader, { | ||||||
|  |     propsData: { | ||||||
|  |       options: [option], | ||||||
|  |     }, | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   await later(); | ||||||
|  |   wrapper.find('.van-cascader__option').trigger('click'); | ||||||
|  |   expect(wrapper.emitted('finish')[0]).toEqual([ | ||||||
|  |     { | ||||||
|  |       value: option.value, | ||||||
|  |       tabIndex: 0, | ||||||
|  |       selectedOptions: [option], | ||||||
|  |     }, | ||||||
|  |   ]); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | test('should emit close event when close icon is clicked', () => { | ||||||
|  |   const wrapper = mount(Cascader); | ||||||
|  |   wrapper.find('.van-cascader__close-icon').trigger('click'); | ||||||
|  |   expect(wrapper.emitted('close')[0]).toBeTruthy(); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | test('should not render close icon when closeable is false', () => { | ||||||
|  |   const wrapper = mount(Cascader, { | ||||||
|  |     propsData: { | ||||||
|  |       closeable: false, | ||||||
|  |     }, | ||||||
|  |   }); | ||||||
|  |   expect(wrapper.contains('.van-cascader__close-icon')).toBeFalsy(); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | test('should render title slot correctly', () => { | ||||||
|  |   const wrapper = mount(Cascader, { | ||||||
|  |     scopedSlots: { | ||||||
|  |       title: () => 'Custom Title', | ||||||
|  |     }, | ||||||
|  |   }); | ||||||
|  |   expect(wrapper.find('.van-cascader__title').html()).toMatchSnapshot(); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | test('should select correct option when value changed', async () => { | ||||||
|  |   const wrapper = mount(Cascader, { | ||||||
|  |     propsData: { | ||||||
|  |       options, | ||||||
|  |     }, | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   await later(); | ||||||
|  |   wrapper.setProps({ value: '330304' }); | ||||||
|  |   await later(); | ||||||
|  |   const selectedOptions = wrapper.findAll('.van-cascader__option--selected'); | ||||||
|  |   const lastSelectedOption = selectedOptions.at(selectedOptions.length - 1); | ||||||
|  |   expect(lastSelectedOption).toMatchSnapshot(); | ||||||
|  | }); | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user