-
Notifications
You must be signed in to change notification settings - Fork 0
67 lines (57 loc) · 2.35 KB
/
copilot-setup-steps.yml
File metadata and controls
67 lines (57 loc) · 2.35 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
name: "Copilot Setup Steps"
# Automatically run the setup steps when they are changed to allow for easy validation, and
# allow manual testing through the repository's "Actions" tab
on:
workflow_dispatch:
push:
paths:
- .github/workflows/copilot-setup-steps.yml
pull_request:
paths:
- .github/workflows/copilot-setup-steps.yml
jobs:
# The job MUST be called `copilot-setup-steps` or it will not be picked up by Copilot.
copilot-setup-steps:
runs-on: ubuntu-latest
# Set the permissions to the lowest permissions possible needed for your steps.
# Copilot will be given its own token for its operations.
permissions:
# If you want to clone the repository as part of your setup steps, for example to install dependencies, you'll need the `contents: read` permission. If you don't clone the repository in your setup steps, Copilot will do this for you automatically after the steps complete.
contents: read
# You can define any steps you want, and they will run before the agent starts.
# If you do not check out your code, Copilot will do this for you.
steps:
- name: Checkout code
uses: actions/checkout@v4
# Setup Go environment for development and testing
- name: Setup Go
uses: actions/setup-go@v5
with:
go-version: '^1.24.2'
cache-dependency-path: go.sum
# Configure Go for private repository access
- name: Configure Go for private repositories
run: |
git config --global url."https://${{ secrets.GITHUB_TOKEN }}@github.com/".insteadOf "https://github.com/"
# Setup Docker for containerized development
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
# Install Go dependencies and development tools
- name: Install Go dependencies and tools
run: |
go mod download
go mod verify
# Install golangci-lint for Go code linting
- name: Install golangci-lint
uses: golangci/golangci-lint-action@v7
continue-on-error: true
with:
version: latest
# Verify all tools are properly installed
- name: Verify tool installations
run: |
echo "=== Tool Versions ==="
go version
golangci-lint version
docker --version
echo "All tools installed successfully!"