Skip to content
This repository has been archived by the owner on Mar 16, 2024. It is now read-only.

Commit

Permalink
Refactor defaults to resolvedOfferings
Browse files Browse the repository at this point in the history
Signed-off-by: Grant Linville <[email protected]>
  • Loading branch information
g-linville committed Dec 7, 2023
1 parent cf5ba1d commit 4aca73a
Show file tree
Hide file tree
Showing 273 changed files with 1,984 additions and 1,218 deletions.
1 change: 1 addition & 0 deletions docs/docs/40-admin/03-computeclasses.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ affinity: # The same affinity fields for Pods
operator: In
values:
- bar
supportedRegions: ["local"] # should always be set to ["local"]
```
If `memory.min`, `memory.max`, `memory.values`, `affinity`, and `tolerations` are not given, then there are no scheduling rules for workloads using the compute class.
Expand Down
5 changes: 1 addition & 4 deletions pkg/apis/api.acorn.io/v1/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,7 @@ func (in *App) GetStopped() bool {
}

func (in *App) GetRegion() string {
if in.Spec.Region != "" {
return in.Spec.Region
}
return in.Status.Defaults.Region
return in.Status.ResolvedOfferings.Region
}

type Acornfile v1.AppSpec
Expand Down
38 changes: 19 additions & 19 deletions pkg/apis/internal.acorn.io/v1/appinstance.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ type AppInstanceCondition string

var (
AppInstanceConditionDefined = "defined"
AppInstanceConditionDefaults = "defaults"
AppInstanceConditionResolvedOfferings = "resolved-offerings"
AppInstanceConditionScheduling = "scheduling"
AppInstanceConditionNamespace = "namespace"
AppInstanceConditionParsed = "parsed"
Expand Down Expand Up @@ -52,24 +52,18 @@ type AppInstance struct {
}

func (in *AppInstance) HasRegion(region string) bool {
return in.Status.Defaults.Region == region || in.Spec.Region == region
return in.Status.ResolvedOfferings.Region == region || in.Spec.Region == region
}

func (in *AppInstance) GetRegion() string {
if in.Spec.Region != "" {
return in.Spec.Region
if in.Status.ResolvedOfferings.Region != "" {
return in.Status.ResolvedOfferings.Region
}
return in.Status.Defaults.Region
return in.Spec.Region
}

func (in *AppInstance) SetDefaultRegion(region string) {
if in.Spec.Region == "" {
if in.Status.Defaults.Region == "" {
in.Status.Defaults.Region = region
}
} else {
in.Status.Defaults.Region = ""
}
in.Status.ResolvedOfferings.Region = region
}

func (in *AppInstance) ShortID() string {
Expand Down Expand Up @@ -209,7 +203,7 @@ type AppInstanceStatus struct {
AppStatus AppStatus `json:"appStatus,omitempty"`
Scheduling map[string]Scheduling `json:"scheduling,omitempty"`
Conditions []Condition `json:"conditions,omitempty"`
Defaults Defaults `json:"defaults,omitempty"`
ResolvedOfferings ResolvedOfferings `json:"resolvedOfferings,omitempty"`
Summary CommonSummary `json:"summary,omitempty"`
Permissions []Permissions `json:"permissions,omitempty"` // Permissions given to this appInstance (only containers within, not nested Acorns/Services)
DeniedConsumerPermissions []Permissions `json:"deniedConsumerPermissions,omitempty"` // Permissions given to this appInstance by a consumed service, which it is not authorized to have
Expand All @@ -229,19 +223,25 @@ type AppStatusStaged struct {
ImageAllowed *bool `json:"imageAllowed,omitempty"`
}

type Defaults struct {
VolumeSize *resource.Quantity `json:"volumeSize,omitempty"`
Volumes map[string]VolumeDefault `json:"volumes,omitempty"`
Memory map[string]*int64 `json:"memory,omitempty"`
Region string `json:"region,omitempty"`
type ResolvedOfferings struct {
Volumes map[string]VolumeResolvedOffering `json:"volumes,omitempty"`
VolumeSize *resource.Quantity `json:"volumeSize,omitempty"`
Containers map[string]ContainerResolvedOffering `json:"containers,omitempty"`
Region string `json:"region,omitempty"`
}

type VolumeDefault struct {
type VolumeResolvedOffering struct {
Class string `json:"class,omitempty"`
Size Quantity `json:"size,omitempty"`
AccessModes AccessModes `json:"accessModes,omitempty"`
}

type ContainerResolvedOffering struct {
Class string `json:"class,omitempty"`
Memory *int64 `json:"memory,omitempty"`
CPUScaler *float64 `json:"cpuScaler,omitempty"`
}

type Scheduling struct {
Requirements corev1.ResourceRequirements `json:"requirements,omitempty"`
Affinity *corev1.Affinity `json:"affinity,omitempty"`
Expand Down
143 changes: 80 additions & 63 deletions pkg/apis/internal.acorn.io/v1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion pkg/cli/testdata/TestAll/acorn_all_-o_json.golden
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ ACORNS:
},
"appSpec": {},
"appStatus": {},
"defaults": {},
"resolvedOfferings": {},
"summary": {}
}
}
Expand Down
2 changes: 1 addition & 1 deletion pkg/cli/testdata/TestAll/acorn_all_-o_yaml.golden
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ items:
appSpec: {}
appStatus: {}
columns: {}
defaults: {}
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down
13 changes: 13 additions & 0 deletions pkg/controller/appdefinition/deploy.go
Original file line number Diff line number Diff line change
Expand Up @@ -597,12 +597,25 @@ func containerAnnotation(container v1.Container) string {
return string(json)
}

func resolvedOfferingsAnnotation(appInstance *v1.AppInstance, container v1.Container) string {
if resolved, exists := appInstance.Status.ResolvedOfferings.Containers[container.Name]; exists {
data, _ := convert.EncodeToMap(resolved)
j, _ := json.Marshal(data)
return string(j)
}
return ""
}

func podAnnotations(appInstance *v1.AppInstance, container v1.Container) map[string]string {
annotations := map[string]string{
labels.AcornContainerSpec: containerAnnotation(container),
}
addPrometheusAnnotations(annotations, container)

if offerings := resolvedOfferingsAnnotation(appInstance, container); offerings != "" {
annotations[labels.AcornContainerResolvedOfferings] = offerings
}

images := map[string]string{}
addImageAnnotations(images, appInstance, container)

Expand Down
6 changes: 3 additions & 3 deletions pkg/controller/appdefinition/testdata/TestComputeMem.golden
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ status:
appSpec: {}
appStatus: {}
columns: {}
defaults: {}
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down Expand Up @@ -157,7 +157,7 @@ status:
appSpec: {}
appStatus: {}
columns: {}
defaults: {}
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down Expand Up @@ -200,8 +200,8 @@ status:
status: "True"
success: true
type: defined
defaults: {}
namespace: app-created-namespace
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ status:
appSpec: {}
appStatus: {}
columns: {}
defaults: {}
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down Expand Up @@ -212,8 +212,8 @@ status:
status: "True"
success: true
type: defined
defaults: {}
namespace: app-created-namespace
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,7 @@ status:
appSpec: {}
appStatus: {}
columns: {}
defaults: {}
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down Expand Up @@ -254,8 +254,8 @@ status:
status: "True"
success: true
type: defined
defaults: {}
namespace: app-created-namespace
resolvedOfferings: {}
staged:
appImage:
buildContext: {}
Expand Down
Loading

0 comments on commit 4aca73a

Please sign in to comment.