feat(experimental/gotls): support stripped and/or PIE enabled binary #438
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Test | |
on: | |
workflow_dispatch: | |
push: | |
branches: [ "master", "dev" ] | |
pull_request: | |
branches: [ "master", "dev" ] | |
permissions: | |
contents: read | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Set up Go | |
uses: actions/setup-go@0a12ed9d6a96ab950c8f026ed9f722fe0da7ef32 # v5 | |
with: | |
go-version: '1.22.4' | |
- name: Build | |
run: make build-via-docker | |
- name: Test | |
run: make test | |
- name: Store executable | |
uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4 | |
with: | |
name: ptcpdump | |
path: ptcpdump | |
e2e-test: | |
name: e2e-test | |
needs: build | |
strategy: | |
fail-fast: false | |
matrix: | |
kernel: | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- '4.19-20240912.022020' | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- '5.4-20240912.022020' | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- '5.10-20240912.022020' | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- '5.15-20240912.022020' | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- '6.1-20240912.022020' | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- '6.6-20240912.022020' | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- 'bpf-20240912.022020' | |
# renovate: datasource=docker depName=quay.io/lvh-images/kernel-images | |
- 'bpf-next-20240912.022020' | |
timeout-minutes: 10 | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Retrieve stored ptcpdump executable | |
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4 | |
with: | |
name: ptcpdump | |
path: ptcpdump | |
- name: Provision LVH VMs | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
test-name: ptcpdump-test | |
image-version: ${{ matrix.kernel }} | |
cpu: 2 | |
mem: '4G' | |
host-mount: ./ | |
install-dependencies: 'true' | |
cmd: | | |
chmod +x /host/ptcpdump/ptcpdump | |
- name: download btf file | |
if: ${{ startsWith(matrix.kernel, '4.') }} | |
run: | | |
img=quay.io/lvh-images/kernel-images:${{ matrix.kernel }} | |
docker pull $img | |
id=$(docker create $img) | |
mkdir data/ | |
docker cp $id:/data/kernels data/ | |
ls -la data/ | |
find data/ -path "*vmlinuz*" -type f | |
find data/ -path "*btf*" -type f | |
- name: copy btf file | |
if: ${{ startsWith(matrix.kernel, '4.') }} | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
uname -a | |
cat /etc/issue | |
cat /etc/os-release | |
sudo mkdir -p /var/lib/ptcpdump/btf/ | |
sudo cp /host/data/kernels/4.*/boot/btf-4.* /var/lib/ptcpdump/btf/vmlinux | |
# btf_file=$(find /host/ -path "*btf*" -type f) | |
# sudo cp $btf_file /var/lib/ptcpdump/btf/vmlinux | |
- name: Test default | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_default.sh /host/ptcpdump/ptcpdump | |
- name: Test base | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_base.sh /host/ptcpdump/ptcpdump | |
- name: Test parent info | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_parent_info.sh /host/ptcpdump/ptcpdump | |
- name: Test filter by process name | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_pname_filter.sh /host/ptcpdump/ptcpdump | |
- name: Test filter by process id | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_pid_filter.sh /host/ptcpdump/ptcpdump | |
- name: Test read pcap file | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_read_pcap.sh /host/ptcpdump/ptcpdump | |
- name: Test write pcap file | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_write_pcap.sh /host/ptcpdump/ptcpdump | |
- name: Test write to stdout | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_write_stdout.sh /host/ptcpdump/ptcpdump | |
- name: Test exist connections | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_exist_connection.sh /host/ptcpdump/ptcpdump | |
- name: Test arp and icmp | |
if: ${{ (!startsWith(matrix.kernel, '5.4')) && (!startsWith(matrix.kernel, '4.')) }} | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_arp.sh /host/ptcpdump/ptcpdump | |
bash /host/testdata/test_icmp.sh /host/ptcpdump/ptcpdump | |
- name: Test run sub program | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
bash /host/testdata/test_sub_program.sh /host/ptcpdump/ptcpdump | |
bash /host/testdata/test_sub_curl_domain_program.sh /host/ptcpdump/ptcpdump | |
- name: Test NAT | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
for i in {1..10}; do | |
bash /host/testdata/test_nat.sh /host/ptcpdump/ptcpdump && exit 0 || sleep 1 | |
done | |
exit 1 | |
- name: build demo app | |
run: | | |
make -C testdata/gohttpapp build | |
- name: Test go tls keylog (unstripped) | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
ls -lh /host/testdata/gohttpapp | |
apt update && yes | apt install -y tshark | |
for i in {1..10}; do | |
bash /host/testdata/test_gotls_keylog.sh /host/ptcpdump/ptcpdump && exit 0 || sleep 1 | |
done | |
exit 1 | |
- name: Test go tls keylog (PIE) | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
ls -lh /host/testdata/gohttpapp | |
apt update && yes | apt install -y tshark | |
for i in {1..10}; do | |
bash /host/testdata/test_gotls_keylog_pie.sh /host/ptcpdump/ptcpdump && exit 0 || sleep 1 | |
done | |
exit 1 | |
- name: Test go tls keylog (stripped) | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
ls -lh /host/testdata/gohttpapp | |
apt update && yes | apt install -y tshark | |
for i in {1..10}; do | |
bash /host/testdata/test_gotls_keylog_stripped.sh /host/ptcpdump/ptcpdump && exit 0 || sleep 1 | |
done | |
exit 1 | |
- name: Test go tls keylog (stripped + PIE) | |
uses: cilium/little-vm-helper@97c89f004bd0ab4caeacfe92ebc956e13e362e6b # v0.0.19 | |
with: | |
provision: 'false' | |
cmd: | | |
set -ex | |
uname -a | |
cat /etc/issue | |
ls -lh /host/testdata/gohttpapp | |
apt update && yes | apt install -y tshark | |
for i in {1..10}; do | |
bash /host/testdata/test_gotls_keylog_stripped_pie.sh /host/ptcpdump/ptcpdump && exit 0 || sleep 1 | |
done | |
exit 1 |