Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Internal: Set image projects via configs #1663

Merged
merged 52 commits into from
Apr 11, 2024
Merged
Show file tree
Hide file tree
Changes from 39 commits
Commits
Show all changes
52 commits
Select commit Hold shift + click to select a range
b052962
initial commit
Subbarker Apr 2, 2024
d2ddb60
more logging
Subbarker Apr 2, 2024
45dcc4a
%v
Subbarker Apr 2, 2024
b999c4c
use platform instead of image
Subbarker Apr 3, 2024
fd1d976
Merge branch 'master' into subbarker-project-prefix
Subbarker Apr 3, 2024
f80933d
Merge branch 'master' into subbarker-project-prefix
Subbarker Apr 4, 2024
8dc21e4
remove imageProject()
Subbarker Apr 4, 2024
9c09a96
revert a good portion and move new logic behind new var: options.imag…
Subbarker Apr 4, 2024
a3e2115
remove imageProject() call
Subbarker Apr 4, 2024
07ffb99
remove extra 'nil'
Subbarker Apr 4, 2024
e5b3a28
Merge branch 'master' into subbarker-project-prefix
Subbarker Apr 4, 2024
9b1cbf2
remove ImageFamily
Subbarker Apr 5, 2024
8d8a1c5
Merge branch 'master' into subbarker-project-prefix
Subbarker Apr 5, 2024
de6708c
pass imagespec instead of platform
Subbarker Apr 5, 2024
8d475b1
call parseImageSpecin SetupVM
Subbarker Apr 5, 2024
eff145f
update soaktest SetupVM
Subbarker Apr 5, 2024
39bfca0
move parseImageSpec inside CreateInstance
Subbarker Apr 5, 2024
e0365ca
pass by reference
Subbarker Apr 5, 2024
f7d0e3f
pass by ref #2
Subbarker Apr 8, 2024
fe36fae
swap platform skip contains
Subbarker Apr 8, 2024
c3f6b1b
same as before, but updated locgic
Subbarker Apr 8, 2024
63bf469
"contains" hax
Subbarker Apr 8, 2024
2fe29e7
imports strings
Subbarker Apr 8, 2024
8903e22
update metadata.yaml files and undo contains changes
Subbarker Apr 8, 2024
22de128
bring back contains hack
Subbarker Apr 8, 2024
9377d75
remove parseimagespec from 3pappstest
Subbarker Apr 8, 2024
5a975b1
stackdriver project for sap
Subbarker Apr 8, 2024
2c1f581
print debugging arm machine type
Subbarker Apr 9, 2024
2df8960
fix print
Subbarker Apr 9, 2024
a15211a
better print debugging
Subbarker Apr 9, 2024
891b6de
undo slicecontains change
Subbarker Apr 9, 2024
44dc650
remove string import
Subbarker Apr 9, 2024
befbdd5
update sap project in kokoro config
Subbarker Apr 9, 2024
ac6b221
print debugging with stripunavailablefields
Subbarker Apr 9, 2024
16b7aee
add printf newlines
Subbarker Apr 9, 2024
d21c5ab
use HasSuffix in SliceContains
Subbarker Apr 9, 2024
e5873dd
one-line logging
Subbarker Apr 10, 2024
fdd65ab
remove print debugging
Subbarker Apr 10, 2024
f1f9863
Merge branch 'master' into subbarker-project-prefix
Subbarker Apr 10, 2024
c35be80
adressing comments
Subbarker Apr 10, 2024
fda9bb6
missing comma
Subbarker Apr 10, 2024
dc7e24e
remove old err
Subbarker Apr 10, 2024
e9ae391
formatting & comments
Subbarker Apr 10, 2024
81bf187
add constructImageSpec
Subbarker Apr 10, 2024
107bbce
remove extra "if"
Subbarker Apr 11, 2024
20adf5b
pointer math
Subbarker Apr 11, 2024
3bc535c
typo
Subbarker Apr 11, 2024
531dc84
lingering refs
Subbarker Apr 11, 2024
9bb3e00
delete oracledb to match master
Subbarker Apr 11, 2024
7d5ca3c
Merge branch 'master' into subbarker-project-prefix
Subbarker Apr 11, 2024
97e57fa
update more docs
Subbarker Apr 11, 2024
4722c08
Merge branch 'master' into subbarker-project-prefix
Subbarker Apr 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion integration_test/agents/agents.go
Original file line number Diff line number Diff line change
Expand Up @@ -866,7 +866,7 @@ func CommonSetupWithExtraCreateArgumentsAndMetadata(t *testing.T, platform strin
logger := gce.SetupLogger(t)
logger.ToMainLog().Println("Calling SetupVM(). For details, see VM_initialization.txt.")
options := gce.VMOptions{
Platform: platform,
ImageSpec: platform,
TimeToLive: "3h",
MachineType: RecommendedMachineType(platform),
ExtraCreateArguments: extraCreateArguments,
Expand Down
102 changes: 47 additions & 55 deletions integration_test/gce/gce_testing.go
Original file line number Diff line number Diff line change
Expand Up @@ -305,43 +305,6 @@ type VM struct {
AlreadyDeleted bool
}

// imageProject returns the image project providing the given image family.
func imageProject(family string) (string, error) {
firstWord := strings.Split(family, "-")[0]
switch firstWord {
case "windows":
return "windows-cloud", nil
case "sql":
return "windows-sql-cloud", nil
case "centos":
return "centos-cloud", nil
case "debian":
return "debian-cloud", nil
case "ubuntu":
return "ubuntu-os-cloud", nil
case "rhel":
// There are a few different cases:
// "rhel-7", "rhel-7-4-sap", and "rhel-7-6-sap-ha".
if strings.Contains(family, "-sap") {
return "rhel-sap-cloud", nil
}
return "rhel-cloud", nil
case "rocky":
return "rocky-linux-cloud", nil
case "opensuse":
return "opensuse-cloud", nil
case "sles":
// There are a few different cases:
// "sles-15" and "sles-15-sp*-sap".
if strings.Contains(family, "-sap") {
return "suse-sap-cloud", nil
}
return "suse-cloud", nil
default:
return "", fmt.Errorf("could not find match for family %s", family)
}
}

// SyslogLocation returns a filesystem path to the system log. This function
// assumes the platform is some kind of Linux.
func SyslogLocation(platform string) string {
Expand Down Expand Up @@ -1020,12 +983,6 @@ func prepareSLES(ctx context.Context, logger *log.Logger, vm *VM) error {
return err
}

var (
overriddenImageFamilies = map[string]string{
"opensuse-leap-15-4": "opensuse-leap-15-4-v20231208-x86-64",
}
)

func addFrameworkMetadata(platform string, inputMetadata map[string]string) (map[string]string, error) {
metadataCopy := make(map[string]string)

Expand Down Expand Up @@ -1103,11 +1060,50 @@ func getVMPlatform(image string, platform string) (string, error) {
return "", errors.New("at least one of image or platform must be specified")
}
Subbarker marked this conversation as resolved.
Show resolved Hide resolved

func parseImageSpec(options *VMOptions) (error) {
Subbarker marked this conversation as resolved.
Show resolved Hide resolved
if options.ImageSpec == "" {
return nil
}

if options.Image != "" || options.ImageProject != "" || options.Platform != "" {
return fmt.Errorf("If options.ImageSpec is set, options.(Image|ImageProject|Platform) cannot be: %+v", options)
}

delim := ""
if strings.Contains(options.ImageSpec, ":"){
delim = ":"
} else if strings.Contains(options.ImageSpec, "="){
delim = "="
} else {
return fmt.Errorf("could not parse options.ImageSpec from struct: %+v", options)
}

s := strings.Split(options.ImageSpec, delim)
options.ImageProject = s[0]

switch delim {
case ":":
options.Platform = s[1]
case "=":
options.Image = s[1]
}

// We do this in case subsequent calls try to expand ImageSpec again.
options.ImageSpec = ""

return nil
}

// attemptCreateInstance creates a VM instance and waits for it to be ready.
// Returns a VM object or an error (never both). The caller is responsible for
// deleting the VM if (and only if) the returned error is nil.
func attemptCreateInstance(ctx context.Context, logger *log.Logger, options VMOptions) (vmToReturn *VM, errToReturn error) {

err := parseImageSpec(&options)
if err != nil {
return nil, err
}

platform, err := getVMPlatform(options.Image, options.Platform)
if err != nil {
return nil, err
Expand Down Expand Up @@ -1148,13 +1144,6 @@ func attemptCreateInstance(ctx context.Context, logger *log.Logger, options VMOp
}
Subbarker marked this conversation as resolved.
Show resolved Hide resolved

imgProject := options.ImageProject
if imgProject == "" {
var err error
imgProject, err = imageProject(vm.Platform)
if err != nil {
return nil, fmt.Errorf("attemptCreateInstance() could not find image project: %v", err)
}
}
newMetadata, err := addFrameworkMetadata(vm.Platform, options.Metadata)
if err != nil {
return nil, fmt.Errorf("attemptCreateInstance() could not construct valid metadata: %v", err)
Expand All @@ -1168,11 +1157,6 @@ func attemptCreateInstance(ctx context.Context, logger *log.Logger, options VMOp

if options.Platform != "" {
imageOrImageFamilyFlag = "--image-family=" + options.Platform

if image, ok := overriddenImageFamilies[options.Platform]; ok {
Subbarker marked this conversation as resolved.
Show resolved Hide resolved
imageOrImageFamilyFlag = "--image=" + image
}

}

imageFamilyScope := options.ImageFamilyScope
Expand Down Expand Up @@ -1333,6 +1317,11 @@ func CreateInstance(origCtx context.Context, logger *log.Logger, options VMOptio
ctx, cancel := context.WithTimeout(origCtx, 3*vmInitTimeout)
defer cancel()

err := parseImageSpec(&options)
Subbarker marked this conversation as resolved.
Show resolved Hide resolved
if err != nil {
return nil, err
}

shouldRetry := func(err error) bool {
// VM creation can hit quota, especially when re-running presubmits,
// or when multple people are running tests.
Expand Down Expand Up @@ -1874,6 +1863,9 @@ func SetupLogger(t *testing.T) *logging.DirectoryLogger {

// VMOptions specifies settings when creating a VM via CreateInstance() or SetupVM().
type VMOptions struct {
// Optional. Can be used to pass image/image family & image project in one
// string. If set, Platform/Image/ImageProject should not be set.
Subbarker marked this conversation as resolved.
Show resolved Hide resolved
ImageSpec string
// Required. Normally passed as --image-family to
// "gcloud compute images create".
Platform string
Expand Down
5 changes: 4 additions & 1 deletion integration_test/metadata/integration_metadata.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import (
"fmt"
"reflect"
"regexp"
"strings"

"cloud.google.com/go/monitoring/apiv3/v2/monitoringpb"
"github.com/go-playground/validator/v10"
Expand Down Expand Up @@ -132,7 +133,9 @@ func UnmarshalAndValidate(data []byte, i interface{}) error {

func SliceContains(slice []string, toFind string) bool {
for _, entry := range slice {
if entry == toFind {
// vm.Platform (ex. `sles-15`) does not align with ImageSpec (ex. `suse-cloud:sles-15`)
// TODO, remove lingering references to "Platform" and use "Image Spec" instead.
if strings.HasSuffix(entry, toFind) {
Subbarker marked this conversation as resolved.
Show resolved Hide resolved
return true
}
}
Expand Down
10 changes: 5 additions & 5 deletions integration_test/soak_test/cmd/launcher/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -122,11 +122,11 @@ func mainErr() error {

// Create the VM.
options := gce.VMOptions{
Platform: distro,
TimeToLive: ttl,
Name: vmName,
MachineType: "e2-standard-16",
Metadata: map[string]string{
ImageSpec: distro,
Subbarker marked this conversation as resolved.
Show resolved Hide resolved
TimeToLive: ttl,
Name: vmName,
MachineType: "e2-standard-16",
Metadata: map[string]string{
// This is to avoid Windows updates and reboots (b/295165549), and
// also to avoid throughput blips when the OS Config agent runs
// periodically.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -131,11 +131,11 @@ minimum_supported_agent_version:
supported_operating_systems: linux
platforms_to_skip:
# Unable to install Aerospike on various distros.
- debian-12
- debian-12-arm64
- sles-12
- rocky-linux-9
- rocky-linux-9-arm64
- ubuntu-2310-amd64
- ubuntu-2310-arm64
- debian-cloud:debian-12
- debian-cloud:debian-12-arm64
- suse-cloud:sles-12
- rocky-linux-cloud:rocky-linux-9
- rocky-linux-cloud:rocky-linux-9-arm64
- ubuntu-os-cloud:ubuntu-2310-amd64
- ubuntu-os-cloud:ubuntu-2310-arm64
public_url: https://cloud.google.com/stackdriver/docs/solutions/agents/ops-agent/third-party/aerospike
Original file line number Diff line number Diff line change
Expand Up @@ -61,10 +61,10 @@ expected_metrics:
server_name: .*
unavailable_on:
# https://github.com/GoogleCloudPlatform/ops-agent/issues/1173
- centos-7
- sles-12
- sles-15
- sles-15-arm64
- centos-cloud:centos-7
- suse-cloud:sles-12
- suse-cloud:sles-15
- suse-cloud:sles-15-arm64
- type: workload.googleapis.com/apache.requests
value_type: INT64
kind: CUMULATIVE
Expand Down Expand Up @@ -171,10 +171,10 @@ expected_logs:
# Unavailable for the same reasons as current_connections,
# described in:
# https://github.com/GoogleCloudPlatform/ops-agent/issues/1173
- centos-7
- sles-12
- sles-15
- sles-15-arm64
- centos-cloud:centos-7
- suse-cloud:sles-12
- suse-cloud:sles-15
- suse-cloud:sles-15-arm64
- name: severity
type: string
description: ''
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,14 +48,14 @@ minimum_supported_agent_version:
supported_operating_systems: linux
# TODO: Fix errors and enable tests on all platforms.
platforms_to_skip:
- centos-7 # see https://issues.apache.org/jira/browse/CASSANDRA-18059 for fix.
- sles-12 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- sles-15 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- sles-15-arm64
- debian-12 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- debian-12-arm64 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- ubuntu-2004-lts # GPG error [...] the public key is not available: NO_PUBKEY AA8E81B4331F7F50 NO_PUBKEY 112695A0E562B32A
- ubuntu-2204-lts # GPG error [...] the public key is not available: NO_PUBKEY AA8E81B4331F7F50 NO_PUBKEY 112695A0E562B32A
- centos-cloud:centos-7 # see https://issues.apache.org/jira/browse/CASSANDRA-18059 for fix.
- suse-cloud:sles-12 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- suse-cloud:sles-15 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- suse-cloud:sles-15-arm64
- debian-cloud:debian-12 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- debian-cloud:debian-12-arm64 # QueryLog() failed: cassandra_system not found, exhausted retries; QueryLog() failed: cassandra_debug not found, exhausted retries; QueryLog() failed: cassandra_gc not found, exhausted retries
- ubuntu-os-cloud:ubuntu-2004-lts # GPG error [...] the public key is not available: NO_PUBKEY AA8E81B4331F7F50 NO_PUBKEY 112695A0E562B32A
- ubuntu-os-cloud:ubuntu-2204-lts # GPG error [...] the public key is not available: NO_PUBKEY AA8E81B4331F7F50 NO_PUBKEY 112695A0E562B32A
supported_app_version: ["3.11", "4.0"]
expected_metrics:
- type: workload.googleapis.com/cassandra.client.request.count
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -200,9 +200,9 @@ supported_operating_systems: linux
platforms_to_skip:
# couchbase is not supported on various distros.
# https://docs.couchbase.com/server/current/install/install-platforms.html
- rocky-linux-9
- debian-11-arm64
- debian-12
- ubuntu-2310-amd64
- ubuntu-2310-arm64
- rocky-linux-cloud:rocky-linux-9
- debian-cloud:debian-11-arm64
- debian-cloud:debian-12
- ubuntu-os-cloud:ubuntu-2310-amd64
- ubuntu-os-cloud:ubuntu-2310-arm64
public_url: https://cloud.google.com/stackdriver/docs/solutions/agents/ops-agent/third-party/couchbase
Original file line number Diff line number Diff line change
Expand Up @@ -29,15 +29,15 @@ minimum_supported_agent_version:
supported_operating_systems: linux
platforms_to_skip:
# couchdb is not supported on various distros.
- sles-12
- sles-15
- sles-15-arm64
- rocky-linux-9
- rocky-linux-9-arm64
- ubuntu-2310-amd64
- ubuntu-2310-arm64
- debian-12
- debian-12-arm64
- suse-cloud:sles-12
- suse-cloud:sles-15
- suse-cloud:sles-15-arm64
- rocky-linux-cloud:rocky-linux-9
- rocky-linux-cloud:rocky-linux-9-arm64
- ubuntu-os-cloud:ubuntu-2310-amd64
- ubuntu-os-cloud:ubuntu-2310-arm64
- debian-cloud:debian-12
- debian-cloud:debian-12-arm64
supported_app_version: ["2.3+", "3.1+"]
expected_metrics:
- type: workload.googleapis.com/couchdb.average_request_time
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,22 +26,22 @@ supported_app_version: ["3.1"]
gpu_platforms: # p4, k80, p100 don't emit DCGM profiling metrics
- model: a100
platforms:
- ubuntu-2004-lts
- ubuntu-os-cloud:ubuntu-2004-lts
- model: v100
platforms:
- ubuntu-2004-lts
- ubuntu-os-cloud:ubuntu-2004-lts
- model: t4
platforms:
- ubuntu-2004-lts
- ubuntu-os-cloud:ubuntu-2004-lts
- model: l4
platforms:
- centos-7
- debian-11
- rocky-linux-8
- rocky-linux-9
- sles-15
- ubuntu-2004-lts
- ubuntu-2204-lts
- centos-cloud:centos-7
- debian-cloud:debian-11
- rocky-linux-cloud:rocky-linux-8
- rocky-linux-cloud:rocky-linux-9
- suse-cloud:sles-15
- ubuntu-os-cloud:ubuntu-2004-lts
- ubuntu-os-cloud:ubuntu-2204-lts
expected_metrics:
- type: workload.googleapis.com/dcgm.gpu.profiling.sm_utilization
value_type: DOUBLE
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,8 @@ description: |-
The result includes fields for source, level, and message.
platforms_to_skip:
# Flink only supports Java 11, which has no installation candidate for Debian 12
- debian-12
- debian-12-arm64
- debian-cloud:debian-12
- debian-cloud:debian-12-arm64
supported_app_version: ["1.12.5", "1.13.6", "1.14.4"]
configure_integration: ""
expected_metrics:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,8 +46,8 @@ minimum_supported_agent_version:
logging: 2.11.0
platforms_to_skip:
# Hbase only supports Java 11, which has no installation candidate for Debian 12
- debian-12
- debian-12-arm64
- debian-cloud:debian-12
- debian-cloud:debian-12-arm64
supported_operating_systems: linux
supported_app_version: ["1.7.x", "2.3.x", "2.4.x"]
expected_metrics:
Expand Down
Loading
Loading