Skip to content

Commit

Permalink
Merging to release-5.3: [TT-13769] Extend plugin compiler test with a…
Browse files Browse the repository at this point in the history
…rm64 cross build (#6813)

[TT-13769] Extend plugin compiler test with arm64 cross build (#6813)

### **PR Type**
tests


___

### **Description**
- Extended the plugin compiler test script to include a
cross-compilation step for the `arm64` architecture.
- Added a Docker command with the `GOARCH=arm64` environment variable to
enable arm64 builds.
- Ensures compatibility and testing for arm64 architecture in the plugin
compiler.



___



### **Changes walkthrough** 📝
<table><thead><tr><th></th><th align="left">Relevant
files</th></tr></thead><tbody><tr><td><strong>Tests</strong></td><td><table>
<tr>
  <td>
    <details>
<summary><strong>test.sh</strong><dd><code>Add arm64 cross-compilation
to plugin compiler test script</code></dd></summary>
<hr>

ci/tests/plugin-compiler/test.sh

<li>Added a cross-compilation step for building the plugin for the
<code>arm64</code> <br>architecture.<br> <li> Introduced the use of the
<code>GOARCH=arm64</code> environment variable in the <br>Docker
command.<br>


</details>


  </td>
<td><a
href="https://github.com/TykTechnologies/tyk/pull/6813/files#diff-2a616e71f9e61519f1e7fcd658f73d83a8ae561ef3108da000e7f5d77e38c244">+3/-0</a>&nbsp;
&nbsp; &nbsp; </td>

</tr>
</table></td></tr></tr></tbody></table>

___

> 💡 **PR-Agent usage**: Comment `/help "your question"` on any pull
request to receive relevant information

---------

Co-authored-by: Tit Petric <tit@tyk.io>

(cherry picked from commit 0486232)
  • Loading branch information
buger authored and Tyk Bot committed Dec 28, 2024
1 parent 0276c06 commit 6a33f15
Show file tree
Hide file tree
Showing 5 changed files with 70 additions and 2 deletions.
6 changes: 6 additions & 0 deletions ci/tests/plugin-compiler/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,12 @@ The following variables are set as defaults:

Use `task -l` to list available targets, or read on.

Example: Run a plugin subtest against a release image.

```
task test:qa-plugin image=tykio/tyk-plugin-compiler:v5.3.9-rc4
```

## Building and testing plugin compiler locally

In order to build the plugin compiler images locally from source,
Expand Down
17 changes: 15 additions & 2 deletions ci/tests/plugin-compiler/Taskfile.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
# yamllint disable rule:line-length
---
version: "3"

Expand Down Expand Up @@ -82,7 +83,6 @@ tasks:
internal: true
cmds:


test:basic-plugin:
desc: "Test plugin compiler (basic-plugin)"
vars:
Expand All @@ -96,6 +96,20 @@ tasks:
- docker run {{.args}} --entrypoint=/usr/local/bin/tyk {{.image}} plugin load -f plugin.so -s {{.symbol}}
- strings {{.plugin_path}}/plugin.so | grep test_goplugin.go

test:qa-plugin:
desc: "Test plugin compiler (qa-plugin) amd64 e2e + arm64 build"
vars:
plugin_path: '{{.root}}/ci/tests/plugin-compiler/testdata/qa-plugin'
symbol: AuthCheck
args: --rm -e DEBUG=1 -v {{.plugin_path}}:/plugin-source -w /plugin-source
cmds:
- rm -f {{.plugin_path}}/*.so
- docker run {{.args}} {{.image}} plugin.so
- cp -f {{.plugin_path}}/*.so {{.plugin_path}}/plugin.so
- docker run -e GOARCH=arm64 {{.args}} {{.image}} plugin.so
- docker run {{.args}} --entrypoint=/usr/local/bin/tyk {{.image}} plugin load -f plugin.so -s {{.symbol}}
- strings {{.plugin_path}}/plugin.so | grep test_goplugin.go

test:basic-plugin-id:
desc: "Test plugin compiler (basic-plugin)"
vars:
Expand Down Expand Up @@ -136,4 +150,3 @@ tasks:
- cp -f {{.plugin_path}}/*.so {{.plugin_path}}/plugin.so
- docker run {{.args}} --entrypoint=/usr/local/bin/tyk {{.image}} plugin load -f plugin.so -s {{.symbol}}
- strings {{.plugin_path}}/plugin.so | grep main.go

3 changes: 3 additions & 0 deletions ci/tests/plugin-compiler/test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ rm -fv $PLUGIN_SOURCE_PATH/*.so || true
docker run --rm -v $PLUGIN_SOURCE_PATH:/plugin-source $PLUGIN_COMPILER_IMAGE plugin.so
cp $PLUGIN_SOURCE_PATH/*.so $PLUGIN_SOURCE_PATH/plugin.so

# Cross compile to arm64
docker run --rm -e GOARCH=arm64 -v $PLUGIN_SOURCE_PATH:/plugin-source $PLUGIN_COMPILER_IMAGE plugin.so

docker compose up -d --wait --force-recreate || { docker compose logs gw; exit 1; }

curl http://localhost:8080/goplugin/headers | jq -e '.headers.Foo == "Bar"' || { docker compose logs gw; exit 1; }
6 changes: 6 additions & 0 deletions ci/tests/plugin-compiler/testdata/qa-plugin/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# QA Plugin

The only difference between this and other plugins is that this one does
not provide a go.mod. This means a slightly different build path is
tested for the plugin compiler, ensuring coverage for when no go.mod is
provided.
40 changes: 40 additions & 0 deletions ci/tests/plugin-compiler/testdata/qa-plugin/main.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
package main

import (
"net/http"

"github.com/TykTechnologies/tyk/ctx"
"github.com/TykTechnologies/tyk/log"
"github.com/TykTechnologies/tyk/user"
)

var logger = log.Get()

// AddFooBarHeader adds custom "Foo: Bar" header to the request
func AddFooBarHeader(rw http.ResponseWriter, r *http.Request) {
r.Header.Add("Foo", "Bar")
}

// Custom Auth, applies a rate limit of
// 2 per 10 given a token of "abc"
func AuthCheck(rw http.ResponseWriter, r *http.Request) {
token := r.Header.Get("Authorization")
if token != "d3fd1a57-94ce-4a36-9dfe-679a8f493b49" && token != "3be61aa4-2490-4637-93b9-105001aa88a5" {
rw.WriteHeader(http.StatusUnauthorized)
return
}
session := &user.SessionState{
Alias: token,
Rate: 2,
Per: 10,
MetaData: map[string]interface{}{
token: token,
},
KeyID: token,
}
ctx.SetSession(r, session, true)
}
func main() {}
func init() {
logger.Info("--- Go custom plugin v4 init success! ---- ")
}

0 comments on commit 6a33f15

Please sign in to comment.