Skip to content

Commit 5a61a5b

Browse files
authored
Merge pull request #231 from crazy-max/lint
lint gha job and remove travis
2 parents 5302241 + f522992 commit 5a61a5b

File tree

13 files changed

+304
-76
lines changed

13 files changed

+304
-76
lines changed

.github/workflows/build.yml

Lines changed: 30 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@ on:
1111

1212
env:
1313
DESTDIR: ./bin
14-
GO_VERSION: 1.16.7
14+
GO_VERSION: 1.18.5
1515

1616
jobs:
1717
validate:
@@ -20,6 +20,7 @@ jobs:
2020
fail-fast: false
2121
matrix:
2222
target:
23+
- lint
2324
- validate-vendor
2425
steps:
2526
-
@@ -58,9 +59,37 @@ jobs:
5859
run: |
5960
sudo apt-get update
6061
sudo apt-get install -y dbus-x11 gnome-keyring libsecret-1-dev pass
62+
-
63+
name: GPG conf
64+
if: ${{ matrix.os == 'ubuntu-20.04' }}
65+
uses: actions/github-script@v6
66+
id: gpg
67+
with:
68+
script: |
69+
const fs = require('fs');
70+
const gnupgfolder = `${require('os').homedir()}/.gnupg`;
71+
if (!fs.existsSync(gnupgfolder)){
72+
fs.mkdirSync(gnupgfolder);
73+
}
74+
fs.copyFile('.github/workflows/fixtures/gpg.conf', `${gnupgfolder}/gpg.conf`, (err) => {
75+
if (err) throw err;
76+
});
77+
core.setOutput('key', fs.readFileSync('.github/workflows/fixtures/7D851EB72D73BDA0.key', {encoding: 'utf8'}));
78+
core.setOutput('passphrase', fs.readFileSync('.github/workflows/fixtures/7D851EB72D73BDA0.pass', {encoding: 'utf8'}));
79+
-
80+
name: Import GPG key
81+
if: ${{ matrix.os == 'ubuntu-20.04' }}
82+
uses: crazy-max/ghaction-import-gpg@v5
83+
with:
84+
gpg_private_key: ${{ steps.gpg.outputs.key }}
85+
passphrase: ${{ steps.gpg.outputs.passphrase }}
6186
-
6287
name: Test
6388
run: |
89+
if [ "${{ matrix.os }}" = "ubuntu-20.04" ]; then
90+
echo -e "trust\n5\ny" | gpg --batch --no-tty --command-fd 0 --edit-key 7D851EB72D73BDA0
91+
pass init 7D851EB72D73BDA0
92+
fi
6493
go test -short -v -coverprofile=./coverage.txt -covermode=atomic ./...
6594
go tool cover -func=./coverage.txt
6695
shell: bash
Lines changed: 106 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,106 @@
1+
-----BEGIN PGP PRIVATE KEY BLOCK-----
2+
3+
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
104+
PejgXO0uIRolYQ3sz2tMGhx1MfBqH64=
105+
=WbwB
106+
-----END PGP PRIVATE KEY BLOCK-----
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
with stupid passphrase
Lines changed: 1 addition & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,6 @@
1+
#!/usr/bin/env sh
12
set -ex
23

3-
sh -e /etc/init.d/xvfb start
4-
sleep 3 # give xvfb some time to start
5-
6-
# init key for pass
74
gpg --batch --gen-key <<-EOF
85
%echo Generating a standard key
96
Key-Type: DSA
@@ -17,6 +14,3 @@ Expire-Date: 0
1714
%commit
1815
%echo done
1916
EOF
20-
21-
key=$(gpg --no-auto-check-trustdb --list-secret-keys | grep ^sec | cut -d/ -f2 | cut -d" " -f1)
22-
pass init $key
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
default-cache-ttl 21600
2+
max-cache-ttl 31536000
3+
allow-preset-passphrase

.github/workflows/fixtures/gpg.conf

Lines changed: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
################################################################################
2+
# GnuPG Options
3+
4+
# (OpenPGP-Configuration-Options)
5+
# Assume that command line arguments are given as UTF8 strings.
6+
utf8-strings
7+
8+
# (OpenPGP-Protocol-Options)
9+
# Set the list of personal digest/cipher/compression preferences. This allows
10+
# the user to safely override the algorithm chosen by the recipient key
11+
# preferences, as GPG will only select an algorithm that is usable by all
12+
# recipients.
13+
personal-digest-preferences SHA512 SHA384 SHA256 SHA224
14+
personal-cipher-preferences AES256 AES192 AES CAST5 CAMELLIA192 BLOWFISH TWOFISH CAMELLIA128 3DES
15+
personal-compress-preferences ZLIB BZIP2 ZIP
16+
17+
# Set the list of default preferences to string. This preference list is used
18+
# for new keys and becomes the default for "setpref" in the edit menu.
19+
default-preference-list SHA512 SHA384 SHA256 SHA224 AES256 AES192 AES CAST5 ZLIB BZIP2 ZIP Uncompressed
20+
21+
# (OpenPGP-Esoteric-Options)
22+
# Use name as the message digest algorithm used when signing a key. Running the
23+
# program with the command --version yields a list of supported algorithms. Be
24+
# aware that if you choose an algorithm that GnuPG supports but other OpenPGP
25+
# implementations do not, then some users will not be able to use the key
26+
# signatures you make, or quite possibly your entire key.
27+
#
28+
# SHA-1 is the only algorithm specified for OpenPGP V4. By changing the
29+
# cert-digest-algo, the OpenPGP V4 specification is not met but with even
30+
# GnuPG 1.4.10 (release 2009) supporting SHA-2 algorithm, this should be safe.
31+
# Source: https://tools.ietf.org/html/rfc4880#section-12.2
32+
cert-digest-algo SHA512
33+
digest-algo SHA256
34+
35+
# Selects how passphrases for symmetric encryption are mangled. 3 (the default)
36+
# iterates the whole process a number of times (see --s2k-count).
37+
s2k-mode 3
38+
39+
# (OpenPGP-Protocol-Options)
40+
# Use name as the cipher algorithm for symmetric encryption with a passphrase
41+
# if --personal-cipher-preferences and --cipher-algo are not given. The
42+
# default is AES-128.
43+
s2k-cipher-algo AES256
44+
45+
# (OpenPGP-Protocol-Options)
46+
# Use name as the digest algorithm used to mangle the passphrases for symmetric
47+
# encryption. The default is SHA-1.
48+
s2k-digest-algo SHA512
49+
50+
# (OpenPGP-Protocol-Options)
51+
# Specify how many times the passphrases mangling for symmetric encryption is
52+
# repeated. This value may range between 1024 and 65011712 inclusive. The
53+
# default is inquired from gpg-agent. Note that not all values in the
54+
# 1024-65011712 range are legal and if an illegal value is selected, GnuPG will
55+
# round up to the nearest legal value. This option is only meaningful if
56+
# --s2k-mode is set to the default of 3.
57+
s2k-count 1015808
58+
59+
################################################################################
60+
# GnuPG View Options
61+
62+
# Select how to display key IDs. "long" is the more accurate (but less
63+
# convenient) 16-character key ID. Add an "0x" to include an "0x" at the
64+
# beginning of the key ID.
65+
keyid-format 0xlong
66+
67+
# List all keys with their fingerprints. This is the same output as --list-keys
68+
# but with the additional output of a line with the fingerprint. If this
69+
# command is given twice, the fingerprints of all secondary keys are listed too.
70+
with-fingerprint
71+
with-fingerprint

.golangci.yml

Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
run:
2+
timeout: 10m
3+
modules-download-mode: vendor
4+
5+
linters:
6+
enable:
7+
- gofmt
8+
- govet
9+
- deadcode
10+
- depguard
11+
- goimports
12+
- ineffassign
13+
- misspell
14+
- unused
15+
- varcheck
16+
- revive
17+
- staticcheck
18+
- typecheck
19+
- structcheck
20+
disable-all: true
21+
22+
linters-settings:
23+
depguard:
24+
list-type: blacklist
25+
include-go-root: true
26+
packages:
27+
# The io/ioutil package has been deprecated.
28+
# https://go.dev/doc/go1.16#ioutil
29+
- io/ioutil
30+
31+
issues:
32+
exclude-rules:
33+
- linters:
34+
- revive
35+
text: "stutters"

.travis.yml

Lines changed: 0 additions & 24 deletions
This file was deleted.

Dockerfile

Lines changed: 24 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,7 @@
33
ARG GO_VERSION=1.18.5
44
ARG XX_VERSION=1.1.2
55
ARG OSXCROSS_VERSION=11.3-r7-alpine
6+
ARG GOLANGCI_LINT_VERSION=v1.47.3
67

78
ARG PKG=github.com/docker/docker-credential-helpers
89

@@ -48,6 +49,14 @@ RUN --mount=type=bind,target=.,rw <<EOT
4849
fi
4950
EOT
5051

52+
FROM golangci/golangci-lint:${GOLANGCI_LINT_VERSION}-alpine AS golangci-lint
53+
FROM gobase AS lint
54+
RUN apk add musl-dev gcc libsecret-dev pass
55+
RUN --mount=type=bind,target=. \
56+
--mount=type=cache,target=/root/.cache \
57+
--mount=from=golangci-lint,source=/usr/bin/golangci-lint,target=/usr/bin/golangci-lint \
58+
golangci-lint run ./...
59+
5160
FROM gobase AS version
5261
ARG PKG
5362
RUN --mount=target=. \
@@ -60,16 +69,28 @@ ARG TARGETPLATFORM
6069
RUN xx-apk add musl-dev gcc libsecret-dev pass
6170

6271
FROM base AS test
72+
RUN xx-apk add gnome-keyring gpg-agent gnupg-gpgconf pass
6373
RUN --mount=type=bind,target=. \
6474
--mount=type=cache,target=/root/.cache \
6575
--mount=type=cache,target=/go/pkg/mod <<EOT
6676
set -e
67-
xx-go test -short -v -coverprofile=/tmp/coverage.txt -covermode=atomic ./...
68-
xx-go tool cover -func=/tmp/coverage.txt
77+
cp -r .github/workflows/fixtures /root/.gnupg
78+
gpg-connect-agent "RELOADAGENT" /bye
79+
gpg --import --batch --yes /root/.gnupg/7D851EB72D73BDA0.key
80+
echo -e "trust\n5\ny" | gpg --batch --no-tty --command-fd 0 --edit-key 7D851EB72D73BDA0
81+
gpg-connect-agent "PRESET_PASSPHRASE 3E2D1142AA59E08E16B7E2C64BA6DDC773B1A627 -1 77697468207374757069642070617373706872617365" /bye
82+
gpg-connect-agent "KEYINFO 3E2D1142AA59E08E16B7E2C64BA6DDC773B1A627" /bye
83+
gpg-connect-agent "PRESET_PASSPHRASE BA83FC8947213477F28ADC019F6564A956456163 -1 77697468207374757069642070617373706872617365" /bye
84+
gpg-connect-agent "KEYINFO BA83FC8947213477F28ADC019F6564A956456163" /bye
85+
pass init 7D851EB72D73BDA0
86+
87+
mkdir /out
88+
xx-go test -short -v -coverprofile=/out/coverage.txt -covermode=atomic ./...
89+
xx-go tool cover -func=/out/coverage.txt
6990
EOT
7091

7192
FROM scratch AS test-coverage
72-
COPY --from=test /tmp/coverage.txt /coverage.txt
93+
COPY --from=test /out /
7394

7495
FROM base AS build-linux
7596
ARG TARGETOS

0 commit comments

Comments
 (0)