@@ -267,7 +267,7 @@ describe('ModelManager', () => {
267267
268268 let props = getLastSelectProps ( ) ;
269269 props . onChange ?.( 'switch' ) ;
270- await time . tick ( 10 ) ;
270+ await time . tick ( 20 ) ;
271271
272272 props = getLastSelectProps ( ) ;
273273 expect ( props . options . map ( ( option ) => option . label ) ) . toContain ( 'Back' ) ;
@@ -289,7 +289,7 @@ describe('ModelManager', () => {
289289
290290 let props = getLastSelectProps ( ) ;
291291 props . onChange ?.( 'switch' ) ;
292- await time . tick ( 10 ) ;
292+ await time . tick ( 20 ) ;
293293
294294 expect ( lastFrame ( ) ) . toContain ( 'gemma4' ) ;
295295 expect ( lastFrame ( ) ) . toContain ( 'Back' ) ;
@@ -323,7 +323,7 @@ describe('ModelManager', () => {
323323
324324 const props = getLastSelectProps ( ) ;
325325 props . onChange ?.( 'switch' ) ;
326- await time . tick ( 10 ) ;
326+ await time . tick ( 20 ) ;
327327
328328 expect ( lastFrame ( ) ) . toContain ( 'Loading models' ) ;
329329
@@ -363,7 +363,7 @@ describe('ModelManager', () => {
363363
364364 props = getLastSelectProps ( ) ;
365365 props . onChange ?.( 'qwen2.5-coder:7b' ) ;
366- await time . tick ( 10 ) ;
366+ await time . tick ( 20 ) ;
367367
368368 expect ( mockPullModel ) . toHaveBeenCalledWith ( 'qwen2.5-coder:7b' ) ;
369369 expect ( lastFrame ( ) ) . toContain ( 'qwen2.5-coder:7b downloaded successfully' ) ;
@@ -388,7 +388,7 @@ describe('ModelManager', () => {
388388
389389 const props = getLastSelectProps ( ) ;
390390 props . onChange ?.( 'download' ) ;
391- await time . tick ( 10 ) ;
391+ await time . tick ( 20 ) ;
392392
393393 const frame = lastFrame ( ) ?? '' ;
394394 expect ( frame ) . not . toContain ( 'Qwen 2.5 Coder' ) ;
@@ -460,7 +460,7 @@ describe('ModelManager', () => {
460460
461461 props = getLastSelectProps ( ) ;
462462 props . onChange ?.( 'qwen2.5-coder:7b' ) ;
463- await time . tick ( 10 ) ;
463+ await time . tick ( 20 ) ;
464464
465465 expect ( lastFrame ( ) ) . toContain ( 'verifying' ) ;
466466 expect ( lastFrame ( ) ) . toContain ( '100%' ) ;
@@ -506,7 +506,7 @@ describe('ModelManager', () => {
506506
507507 let props = getLastSelectProps ( ) ;
508508 props . onChange ?.( 'download' ) ;
509- await time . tick ( 10 ) ;
509+ await time . tick ( 20 ) ;
510510
511511 props = getLastSelectProps ( ) ;
512512 props . onChange ?.( 'qwen2.5-coder:7b' ) ;
@@ -553,7 +553,7 @@ describe('ModelManager', () => {
553553
554554 props = getLastSelectProps ( ) ;
555555 props . onChange ?.( 'qwen2.5-coder:7b' ) ;
556- await time . tick ( 10 ) ;
556+ await time . tick ( 20 ) ;
557557
558558 expect ( lastFrame ( ) ) . toContain ( 'Choose a model to download' ) ;
559559 expect ( lastFrame ( ) ) . toContain ( 'Download canceled' ) ;
@@ -601,7 +601,7 @@ describe('ModelManager', () => {
601601
602602 props = getLastSelectProps ( ) ;
603603 props . onChange ?.( 'qwen2.5-coder:7b' ) ;
604- await time . tick ( 10 ) ;
604+ await time . tick ( 20 ) ;
605605
606606 expect ( lastFrame ( ) ) . toContain ( 'pulling' ) ;
607607
@@ -611,6 +611,7 @@ describe('ModelManager', () => {
611611
612612 it ( 'shows download progress with large file sizes' , async ( ) => {
613613 let finishDownload : ( ( ) => void ) | undefined ;
614+
614615 mockPullModel . mockResolvedValueOnce ( {
615616 abort : vi . fn ( ) ,
616617 async * [ Symbol . asyncIterator ] ( ) {
@@ -636,15 +637,14 @@ describe('ModelManager', () => {
636637 /> ,
637638 ) ;
638639
639- await time . tick ( 10 ) ;
640-
640+ await time . tick ( 20 ) ;
641641 let props = getLastSelectProps ( ) ;
642642 props . onChange ?.( 'download' ) ;
643- await time . tick ( 10 ) ;
643+ await time . tick ( 20 ) ;
644644
645645 props = getLastSelectProps ( ) ;
646646 props . onChange ?.( 'qwen2.5-coder:7b' ) ;
647- await time . tick ( 10 ) ;
647+ await time . tick ( 20 ) ;
648648
649649 expect ( lastFrame ( ) ) . toContain ( 'downloading' ) ;
650650 expect ( lastFrame ( ) ) . toContain ( 'GB' ) ;
@@ -689,7 +689,7 @@ describe('ModelManager', () => {
689689
690690 props = getLastSelectProps ( ) ;
691691 props . onChange ?.( 'qwen2.5-coder:7b' ) ;
692- await time . tick ( 10 ) ;
692+ await time . tick ( 20 ) ;
693693
694694 expect ( lastFrame ( ) ) . toContain ( 'Downloading model' ) ;
695695
@@ -721,7 +721,7 @@ describe('ModelManager', () => {
721721
722722 props = getLastSelectProps ( ) ;
723723 props . onChange ?.( 'custom' ) ;
724- await time . tick ( 10 ) ;
724+ await time . tick ( 20 ) ;
725725
726726 const textInputProps = getLastTextInputProps ( ) ;
727727 textInputProps . onSubmit ( '' ) ;
@@ -747,7 +747,7 @@ describe('ModelManager', () => {
747747
748748 props = getLastSelectProps ( ) ;
749749 props . onChange ?.( 'custom' ) ;
750- await time . tick ( 10 ) ;
750+ await time . tick ( 20 ) ;
751751
752752 const textInputProps = getLastTextInputProps ( ) ;
753753 textInputProps . onSubmit ( 'gemma4' ) ; // Already installed
@@ -785,7 +785,7 @@ describe('ModelManager', () => {
785785
786786 props = getLastSelectProps ( ) ;
787787 props . onChange ?.( 'custom' ) ;
788- await time . tick ( 10 ) ;
788+ await time . tick ( 20 ) ;
789789
790790 const textInputProps = getLastTextInputProps ( ) ;
791791 textInputProps . onSubmit ( 'newmodel' ) ;
@@ -834,7 +834,7 @@ describe('ModelManager', () => {
834834
835835 props = getLastSelectProps ( ) ;
836836 props . onChange ?.( 'custom' ) ;
837- await time . tick ( 10 ) ;
837+ await time . tick ( 20 ) ;
838838
839839 // Simulate typing a value with a colon so the mock ModelSuggestions triggers onSelect
840840 const textInputProps = getLastTextInputProps ( ) ;
@@ -863,12 +863,12 @@ describe('ModelManager', () => {
863863
864864 props = getLastSelectProps ( ) ;
865865 props . onChange ?.( 'custom' ) ;
866- await time . tick ( 10 ) ;
866+ await time . tick ( 20 ) ;
867867
868868 // Type a value with ':' so the mock triggers onSelect (sets highlightedSuggestion)
869869 const textInputProps = getLastTextInputProps ( ) ;
870870 textInputProps . onChange ( 'gemma:latest' ) ;
871- await time . tick ( 10 ) ;
871+ await time . tick ( 20 ) ;
872872
873873 // Submit triggers pull with the highlighted suggestion
874874 const updatedTextInputProps = getLastTextInputProps ( ) ;
@@ -896,7 +896,7 @@ describe('ModelManager', () => {
896896
897897 props = getLastSelectProps ( ) ;
898898 props . onChange ?.( 'custom' ) ;
899- await time . tick ( 10 ) ;
899+ await time . tick ( 20 ) ;
900900
901901 expect ( getLastTextInputProps ( ) . placeholder ) . toBe ( 'name:tag' ) ;
902902
@@ -923,7 +923,7 @@ describe('ModelManager', () => {
923923
924924 props = getLastSelectProps ( ) ;
925925 props . onChange ?.( 'custom' ) ;
926- await time . tick ( 10 ) ;
926+ await time . tick ( 20 ) ;
927927
928928 expect ( getLastTextInputProps ( ) . placeholder ) . toBe ( 'name:tag' ) ;
929929
@@ -948,7 +948,7 @@ describe('ModelManager', () => {
948948
949949 let props = getLastSelectProps ( ) ;
950950 props . onChange ?.( 'delete' ) ;
951- await time . tick ( 10 ) ;
951+ await time . tick ( 20 ) ;
952952
953953 props = getLastSelectProps ( ) ;
954954 expect ( props . options . map ( ( option ) => option . value ) ) . not . toContain (
@@ -997,8 +997,10 @@ describe('ModelManager', () => {
997997
998998 props = getLastSelectProps ( ) ;
999999 props . onChange ?.( 'delete' ) ;
1000+ await time . tick ( ) ;
1001+
10001002 props . onChange ?.( 'delete' ) ;
1001- await time . tick ( 10 ) ;
1003+ await time . tick ( 20 ) ;
10021004
10031005 expect ( mockDeleteModel ) . toHaveBeenCalledTimes ( 1 ) ;
10041006
@@ -1021,48 +1023,20 @@ describe('ModelManager', () => {
10211023
10221024 let props = getLastSelectProps ( ) ;
10231025 props . onChange ?.( 'delete' ) ;
1024- await time . tick ( 10 ) ;
1026+ await time . tick ( 20 ) ;
10251027
10261028 props = getLastSelectProps ( ) ;
10271029 props . onChange ?.( 'llama3' ) ;
1028- await time . tick ( 10 ) ;
1030+ await time . tick ( 20 ) ;
10291031
10301032 props = getLastSelectProps ( ) ;
10311033 props . onChange ?.( 'delete' ) ;
1032- await time . tick ( 10 ) ;
1034+ await time . tick ( 20 ) ;
10331035
10341036 expect ( lastFrame ( ) ) . toContain ( 'Error deleting model' ) ;
10351037 expect ( lastFrame ( ) ) . toContain ( 'Delete failed' ) ;
10361038 } ) ;
10371039
1038- it ( 'shows loading spinner when navigating to delete view while models are loading' , async ( ) => {
1039- let resolveList : ( ( models : string [ ] ) => void ) | undefined ;
1040- mockListModels . mockReturnValueOnce (
1041- new Promise ( ( resolve ) => {
1042- resolveList = resolve ;
1043- } ) ,
1044- ) ;
1045-
1046- const { lastFrame } = render (
1047- < ModelManager
1048- currentModel = "gemma4"
1049- onSelect = { vi . fn ( ) }
1050- onClose = { vi . fn ( ) }
1051- /> ,
1052- ) ;
1053-
1054- await time . tick ( 10 ) ;
1055-
1056- const props = getLastSelectProps ( ) ;
1057- props . onChange ?.( 'delete' ) ;
1058- await time . tick ( 10 ) ;
1059-
1060- expect ( lastFrame ( ) ) . toContain ( 'Loading models' ) ;
1061-
1062- resolveList ?.( [ 'gemma4' , 'llama3' ] ) ;
1063- await time . tick ( 10 ) ;
1064- } ) ;
1065-
10661040 it ( 'shows deleting spinner while deletion is in progress' , async ( ) => {
10671041 let resolveDelete : ( ( ) => void ) | undefined ;
10681042 mockDeleteModel . mockReturnValueOnce (
@@ -1091,7 +1065,7 @@ describe('ModelManager', () => {
10911065
10921066 props = getLastSelectProps ( ) ;
10931067 props . onChange ?.( 'delete' ) ;
1094- await time . tick ( 10 ) ;
1068+ await time . tick ( 20 ) ;
10951069
10961070 expect ( lastFrame ( ) ) . toContain ( 'Deleting model llama3' ) ;
10971071
@@ -1140,7 +1114,7 @@ describe('ModelManager', () => {
11401114
11411115 props = getLastSelectProps ( ) ;
11421116 props . onChange ?.( 'llama3' ) ;
1143- await time . tick ( 10 ) ;
1117+ await time . tick ( 20 ) ;
11441118
11451119 expect ( lastFrame ( ) ) . toContain ( 'Delete model llama3' ) ;
11461120
@@ -1161,15 +1135,14 @@ describe('ModelManager', () => {
11611135 /> ,
11621136 ) ;
11631137
1164- await time . tick ( 10 ) ;
1165-
1138+ await time . tick ( 20 ) ;
11661139 let props = getLastSelectProps ( ) ;
11671140 props . onChange ?.( 'delete' ) ;
1168- await time . tick ( 10 ) ;
1141+ await time . tick ( 20 ) ;
11691142
11701143 props = getLastSelectProps ( ) ;
11711144 props . onChange ?.( 'llama3' ) ;
1172- await time . tick ( 10 ) ;
1145+ await time . tick ( 20 ) ;
11731146
11741147 expect ( lastFrame ( ) ) . toContain ( 'Delete model llama3' ) ;
11751148
0 commit comments