Skip to content

Commit

Permalink
nit and added negative tests
Browse files Browse the repository at this point in the history
nit

nit
  • Loading branch information
vicentefb committed May 1, 2024
1 parent 3f537cb commit 3b014d9
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 3 deletions.
3 changes: 1 addition & 2 deletions pkg/cloudproduct/gke/gke.go
Original file line number Diff line number Diff line change
Expand Up @@ -162,7 +162,7 @@ func (*gkeAutopilot) MutateGameServerPod(gss *agonesv1.GameServerSpec, pod *core
}

// setPassthroughLabel sets the agones.dev/port: "autopilot-passthrough" label to the game server container.
// This will help to back the container port from the allocated port using an objectSelect of this label
// This will help to back the container port from the allocated port using an objectSelector of this label
// in GameServers that are using Passthrough Port Policy
func setPassthroughLabel(gs *agonesv1.GameServerSpec, pod *corev1.Pod) {
if runtime.FeatureEnabled(runtime.FeatureAutopilotPassthroughPort) && hasPortPolicy(gs, agonesv1.Passthrough) {
Expand All @@ -179,7 +179,6 @@ func setPrimaryContainer(pod *corev1.Pod, containerName string) {
return
}
pod.ObjectMeta.Annotations[primaryContainerAnnotation] = containerName

}

// podSpecSeccompUnconfined sets to seccomp profile to `Unconfined` to avoid serious performance
Expand Down
48 changes: 48 additions & 0 deletions pkg/cloudproduct/gke/gke_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,54 @@ func TestSetPassthroughLabel(t *testing.T) {
},
},
},
"gameserver with Static port policy does not add label to pod": {
features: fmt.Sprintf("%s=true", runtime.FeatureAutopilotPassthroughPort),

pod: &corev1.Pod{
ObjectMeta: metav1.ObjectMeta{
Annotations: map[string]string{},
Labels: map[string]string{},
},
},
ports: []agonesv1.GameServerPort{
{
Name: "awesome-udp",
PortPolicy: agonesv1.Static,
ContainerPort: 1234,
Protocol: corev1.ProtocolUDP,
},
},
wantPod: &corev1.Pod{
ObjectMeta: metav1.ObjectMeta{
Annotations: map[string]string{},
Labels: map[string]string{},
},
},
},
"gameserver, no feature gate, with Passthrough port policy does not add label to pod": {
features: fmt.Sprintf("%s=false", runtime.FeatureAutopilotPassthroughPort),

pod: &corev1.Pod{
ObjectMeta: metav1.ObjectMeta{
Annotations: map[string]string{},
Labels: map[string]string{},
},
},
ports: []agonesv1.GameServerPort{
{
Name: "awesome-udp",
PortPolicy: agonesv1.Passthrough,
ContainerPort: 1234,
Protocol: corev1.ProtocolUDP,
},
},
wantPod: &corev1.Pod{
ObjectMeta: metav1.ObjectMeta{
Annotations: map[string]string{},
Labels: map[string]string{},
},
},
},
} {
t.Run(name, func(t *testing.T) {
runtime.FeatureTestMutex.Lock()
Expand Down
1 change: 0 additions & 1 deletion pkg/gameservers/controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -521,7 +521,6 @@ func (c *Controller) syncGameServerCreatingState(ctx context.Context, gs *agones
})
}
}

gs, err = c.createGameServerPod(ctx, gs)
if err != nil || gs.Status.State == agonesv1.GameServerStateError {
return gs, err
Expand Down

0 comments on commit 3b014d9

Please sign in to comment.