@@ -586,3 +586,111 @@ func TestRemoveCondition(t *testing.T) {
586
586
}
587
587
}
588
588
}
589
+
590
+ func TestRolloutExceededTimeoutSeconds (t * testing.T ) {
591
+ now := time .Now ()
592
+ tests := []struct {
593
+ name string
594
+ config func (int64 ) * deployapi.DeploymentConfig
595
+ timeoutSeconds int64
596
+ deploymentCreationTime time.Time
597
+ expectTimeout bool
598
+ }{
599
+ // Recreate strategy with deployment running for 20s (exceeding 10s timeout)
600
+ {
601
+ name : "recreate timeout" ,
602
+ config : func (timeoutSeconds int64 ) * deployapi.DeploymentConfig {
603
+ config := deploytest .OkDeploymentConfig (1 )
604
+ config .Spec .Strategy .RecreateParams .TimeoutSeconds = & timeoutSeconds
605
+ return config
606
+ },
607
+ timeoutSeconds : int64 (10 ),
608
+ deploymentCreationTime : now .Add (- 20 * time .Second ),
609
+ expectTimeout : true ,
610
+ },
611
+ // Recreate strategy with no timeout
612
+ {
613
+ name : "recreate no timeout" ,
614
+ config : func (timeoutSeconds int64 ) * deployapi.DeploymentConfig {
615
+ config := deploytest .OkDeploymentConfig (1 )
616
+ config .Spec .Strategy .RecreateParams .TimeoutSeconds = & timeoutSeconds
617
+ return config
618
+ },
619
+ timeoutSeconds : int64 (0 ),
620
+ deploymentCreationTime : now .Add (- 700 * time .Second ),
621
+ expectTimeout : false ,
622
+ },
623
+
624
+ // Rolling strategy with deployment running for 20s (exceeding 10s timeout)
625
+ {
626
+ name : "rolling timeout" ,
627
+ config : func (timeoutSeconds int64 ) * deployapi.DeploymentConfig {
628
+ config := deploytest .OkDeploymentConfig (1 )
629
+ config .Spec .Strategy = deploytest .OkRollingStrategy ()
630
+ config .Spec .Strategy .RollingParams .TimeoutSeconds = & timeoutSeconds
631
+ return config
632
+ },
633
+ timeoutSeconds : int64 (10 ),
634
+ deploymentCreationTime : now .Add (- 20 * time .Second ),
635
+ expectTimeout : true ,
636
+ },
637
+ // Rolling strategy with deployment with no timeout specified.
638
+ {
639
+ name : "rolling using default timeout" ,
640
+ config : func (timeoutSeconds int64 ) * deployapi.DeploymentConfig {
641
+ config := deploytest .OkDeploymentConfig (1 )
642
+ config .Spec .Strategy = deploytest .OkRollingStrategy ()
643
+ config .Spec .Strategy .RollingParams .TimeoutSeconds = nil
644
+ return config
645
+ },
646
+ deploymentCreationTime : now .Add (- 20 * time .Second ),
647
+ expectTimeout : false ,
648
+ },
649
+ // Recreate strategy with deployment with no timeout specified.
650
+ {
651
+ name : "recreate using default timeout" ,
652
+ config : func (timeoutSeconds int64 ) * deployapi.DeploymentConfig {
653
+ config := deploytest .OkDeploymentConfig (1 )
654
+ config .Spec .Strategy .RecreateParams .TimeoutSeconds = nil
655
+ return config
656
+ },
657
+ deploymentCreationTime : now .Add (- 20 * time .Second ),
658
+ expectTimeout : false ,
659
+ },
660
+ // Custom strategy with deployment with no timeout specified.
661
+ {
662
+ name : "custom using default timeout" ,
663
+ config : func (timeoutSeconds int64 ) * deployapi.DeploymentConfig {
664
+ config := deploytest .OkDeploymentConfig (1 )
665
+ config .Spec .Strategy = deploytest .OkCustomStrategy ()
666
+ return config
667
+ },
668
+ deploymentCreationTime : now .Add (- 20 * time .Second ),
669
+ expectTimeout : false ,
670
+ },
671
+ // Custom strategy use default timeout exceeding it.
672
+ {
673
+ name : "custom using default timeout timing out" ,
674
+ config : func (timeoutSeconds int64 ) * deployapi.DeploymentConfig {
675
+ config := deploytest .OkDeploymentConfig (1 )
676
+ config .Spec .Strategy = deploytest .OkCustomStrategy ()
677
+ return config
678
+ },
679
+ deploymentCreationTime : now .Add (- 700 * time .Second ),
680
+ expectTimeout : true ,
681
+ },
682
+ }
683
+
684
+ for _ , tc := range tests {
685
+ config := tc .config (tc .timeoutSeconds )
686
+ deployment , err := MakeDeploymentV1 (config , kapi .Codecs .LegacyCodec (deployv1 .SchemeGroupVersion ))
687
+ if err != nil {
688
+ t .Fatalf ("unexpected error: %v" , err )
689
+ }
690
+ deployment .ObjectMeta .CreationTimestamp = metav1.Time {Time : tc .deploymentCreationTime }
691
+ gotTimeout := RolloutExceededTimeoutSeconds (config , deployment )
692
+ if tc .expectTimeout && ! gotTimeout {
693
+ t .Errorf ("[%s]: expected timeout, but got no timeout" , tc .name )
694
+ }
695
+ }
696
+ }
0 commit comments