-
Notifications
You must be signed in to change notification settings - Fork 35
Expand file tree
/
Copy pathopenshift_ai.go
More file actions
112 lines (100 loc) · 3.88 KB
/
Copy pathopenshift_ai.go
File metadata and controls
112 lines (100 loc) · 3.88 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package profile
import (
"fmt"
"time"
"github.com/pulumi/pulumi-kubernetes/sdk/v4/go/kubernetes/apiextensions"
metav1 "github.com/pulumi/pulumi-kubernetes/sdk/v4/go/kubernetes/meta/v1"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
"k8s.io/apimachinery/pkg/runtime/schema"
)
const (
rhoaiNamespace = "redhat-ods-operator"
)
var (
dscGVR = schema.GroupVersionResource{
Group: "datasciencecluster.opendatahub.io",
Version: "v1",
Resource: "datascienceclusters",
}
)
// deployOpenShiftAI installs the RHOAI operator and creates a DataScienceCluster.
// The entire RHOAI installation is gated on prereqs (ServiceMesh v2, Authorino,
// and Serverless readiness outputs) so that when the operator starts and auto-creates
// the DSCI, it finds all dependencies already in place.
func deployOpenShiftAI(ctx *pulumi.Context, args *DeployArgs, prereqs []pulumi.StringOutput) (pulumi.Resource, error) {
goCtx := ctx.Context()
rn := func(suffix string) string {
return fmt.Sprintf("%s-rhoai-%s", args.Prefix, suffix)
}
// Gate the entire RHOAI installation on prerequisites.
// The namespace name won't resolve until all prereqs are ready,
// which delays the operator install until SM v2 + Authorino +
// Serverless are fully operational.
nsName := pulumi.String(rhoaiNamespace).ToStringOutput()
for _, p := range prereqs {
prev := nsName
nsName = pulumi.All(prev, p).ApplyT(
func(args []interface{}) string {
return args[0].(string)
}).(pulumi.StringOutput)
}
// Install the RHOAI operator (gated on prereqs via nsName)
csvReady, err := installOperator(ctx, args, operatorInstall{
resourcePrefix: rn(""),
namespace: rhoaiNamespace,
nsName: nsName,
ogName: "redhat-ods-operator-group",
subName: "rhods-operator",
packageName: "rhods-operator",
csvPrefix: "rhods-operator",
})
if err != nil {
return nil, err
}
// Create DataScienceCluster CR after RHOAI CSV is ready.
dscName := csvReady.ApplyT(func(_ string) string {
return "default-dsc"
}).(pulumi.StringOutput)
dsc, err := apiextensions.NewCustomResource(ctx, rn("dsc"),
&apiextensions.CustomResourceArgs{
ApiVersion: pulumi.String("datasciencecluster.opendatahub.io/v1"),
Kind: pulumi.String("DataScienceCluster"),
Metadata: &metav1.ObjectMetaArgs{
Name: dscName,
},
OtherFields: map[string]interface{}{
"spec": map[string]interface{}{
"components": map[string]interface{}{
"dashboard": map[string]interface{}{"managementState": "Managed"},
"workbenches": map[string]interface{}{"managementState": "Managed"},
"datasciencepipelines": map[string]interface{}{"managementState": "Managed"},
"kserve": map[string]interface{}{"managementState": "Managed"},
"modelmeshserving": map[string]interface{}{"managementState": "Removed"},
"ray": map[string]interface{}{"managementState": "Managed"},
"kueue": map[string]interface{}{"managementState": "Removed"},
"trustyai": map[string]interface{}{"managementState": "Managed"},
"codeflare": map[string]interface{}{"managementState": "Managed"},
"trainingoperator": map[string]interface{}{"managementState": "Removed"},
"modelregistry": map[string]interface{}{"managementState": "Removed"},
},
},
},
},
args.k8sOpts()...)
if err != nil {
return nil, err
}
// Wait for DataScienceCluster to be ready.
dscReady := pulumi.All(dsc.ID(), args.Kubeconfig).ApplyT(
func(allArgs []interface{}) (string, error) {
kc := allArgs[1].(string)
if err := waitForCRCondition(goCtx, kc, dscGVR,
"", "default-dsc",
"", "Ready", "True", 40*time.Minute, false); err != nil {
return "", fmt.Errorf("waiting for DataScienceCluster: %w", err)
}
return "ready", nil
}).(pulumi.StringOutput)
ctx.Export("dscReady", dscReady)
return dsc, nil
}