Skip to content

Commit

Permalink
Merge branch 'master' into thor-e2e-test
Browse files Browse the repository at this point in the history
  • Loading branch information
darrenvechain authored Jan 12, 2024
2 parents 59588d6 + d73c32b commit 10b09c1
Show file tree
Hide file tree
Showing 14 changed files with 106 additions and 28 deletions.
7 changes: 7 additions & 0 deletions .github/CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,11 @@ current development landscape.

- We follow the [Effective Go](https://golang.org/doc/effective_go) guidelines. Please make sure your code is idiomatic
and follows the guidelines.

### Code Linting

- We employ `golangci-lint` for code linting in our development process. It ensures that code adheres to established standards, and any changes that do not pass the linting checks will trigger an error during the Continuous Integration (CI) process.
- You can run it locally by installing the `golangci-lint` binary and running `make lint` in the root directory of the repository.

## Testing

Expand Down Expand Up @@ -104,3 +109,5 @@ cd tests/thor-e2e-tests
yarn install
yarn test
```
=======
31 changes: 31 additions & 0 deletions .github/workflows/lint-go.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
name: Lint

on:
push:
branches:
- master
pull_request:

permissions:
contents: read

jobs:
golangci:
name: golangci-lint
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-go@v4
with:
go-version: '1.21'
cache: false
- name: golangci-lint
uses: golangci/golangci-lint-action@v3
with:
version: v1.54
# use the default if on main branch, otherwise use the pull request config
args: --timeout=30m --config=${{ github.event_name == 'pull_request' && '.golangci.pull-request.yml' || '.golangci.yml' }}
only-new-issues: true
skip-cache: true
skip-pkg-cache: true
skip-build-cache: true
13 changes: 13 additions & 0 deletions .golangci.pull-request.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# Please refer to the official golangci-lint config documentation for more details:
# https://golangci-lint.run/usage/configuration/
# https://github.com/golangci/golangci-lint/blob/master/.golangci.reference.yml

linters:
enable-all: true

run:
timeout: 10m
tests: false

issues:
max-issues-per-linter: 1000
15 changes: 15 additions & 0 deletions .golangci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Please refer to the official golangci-lint config documentation for more details:
# https://golangci-lint.run/usage/configuration/
# https://github.com/golangci/golangci-lint/blob/master/.golangci.reference.yml

linters:
disable:
- unused
- errcheck

run:
timeout: 10m
tests: false

issues:
max-issues-per-linter: 1000
26 changes: 19 additions & 7 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,15 @@ export GO111MODULE=on

.PHONY: thor disco all clean test

thor:| go_version_check
help:
@egrep -h '\s#@\s' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?#@ "}; {printf "\033[36m %-30s\033[0m %s\n", $$1, $$2}'

thor:| go_version_check #@ Build the `thor` executable
@echo "building $@..."
@go build -v -o $(CURDIR)/bin/$@ -ldflags "-X main.version=$(THOR_VERSION) -X main.gitCommit=$(GIT_COMMIT) -X main.gitTag=$(GIT_TAG)" ./cmd/thor
@echo "done. executable created at 'bin/$@'"

disco:| go_version_check
disco:| go_version_check #@ Build the `disco` executable
@echo "building $@..."
@go build -v -o $(CURDIR)/bin/$@ -ldflags "-X main.version=$(DISCO_VERSION) -X main.gitCommit=$(GIT_COMMIT) -X main.gitTag=$(GIT_TAG)" ./cmd/disco
@echo "done. executable created at 'bin/$@'"
Expand All @@ -37,16 +40,25 @@ go_version_check:
fi \
fi

all: thor disco
all: thor disco #@ Build the `thor` and `disco` executables

clean:
clean: #@ Clean the build artifacts
-rm -rf \
$(CURDIR)/bin/thor \
$(CURDIR)/bin/disco
$(CURDIR)/bin/disco

test:| go_version_check
test:| go_version_check #@ Run the tests
@go test -cover $(PACKAGES)

test-coverage:| go_version_check
test-coverage:| go_version_check #@ Run the tests with coverage
@go test -race -coverprofile=coverage.out -covermode=atomic $(PACKAGES)
@go tool cover -html=coverage.out

lint_command_check:
@command -v golangci-lint || (echo "golangci-lint not found, please install it from https://golangci-lint.run/usage/install/" && exit 1)

lint: | go_version_check lint_command_check #@ Run 'golangci-lint' on new code changes
@golangci-lint run --new --config .golangci.pull-request.yml

lint-all: | go_version_check lint_command_check #@ Run 'golangci-lint' on the entire codebase
@golangci-lint run --config .golangci.yml
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,8 @@ git clone https://github.com/vechain/thor.git
cd thor
```

To see a list of all available commands, run `make help`

### Building

To build the main app `thor`, just run
Expand Down Expand Up @@ -209,3 +211,5 @@ A special shout out to following projects:
Vechain Thor is licensed under the
[GNU Lesser General Public License v3.0](https://www.gnu.org/licenses/lgpl-3.0.html), also included
in *LICENSE* file in repository.


4 changes: 1 addition & 3 deletions api/accounts/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,9 +59,7 @@ func convertCallResultWithInputGas(vo *runtime.Output, inputGas uint64) *CallRes
Data: hexutil.Encode(txEvent.Data),
}
event.Topics = make([]thor.Bytes32, len(txEvent.Topics))
for k, topic := range txEvent.Topics {
event.Topics[k] = topic
}
copy(event.Topics, txEvent.Topics)
events[j] = event
}
for j, txTransfer := range vo.Transfers {
Expand Down
4 changes: 1 addition & 3 deletions api/transactions/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -205,9 +205,7 @@ func convertReceipt(txReceipt *tx.Receipt, header *block.Header, tx *tx.Transact
Data: hexutil.Encode(txEvent.Data),
}
event.Topics = make([]thor.Bytes32, len(txEvent.Topics))
for k, topic := range txEvent.Topics {
event.Topics[k] = topic
}
copy(event.Topics, txEvent.Topics)
otp.Events[j] = event

}
Expand Down
8 changes: 4 additions & 4 deletions cmd/thor/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,15 @@ package main
import (
"encoding/json"
"fmt"
"io/ioutil"
"io"
"os"
"path/filepath"
"time"

"github.com/ethereum/go-ethereum/accounts/keystore"
"github.com/ethereum/go-ethereum/crypto"
"github.com/inconshreveable/log15"
isatty "github.com/mattn/go-isatty"
"github.com/mattn/go-isatty"

Check failure on line 19 in cmd/thor/main.go

View workflow job for this annotation

GitHub Actions / golangci-lint

import 'github.com/mattn/go-isatty' is not allowed from list 'Main' (depguard)
"github.com/pborman/uuid"
"github.com/pkg/errors"
"github.com/vechain/thor/v2/api"
Expand All @@ -30,7 +30,7 @@ import (
"github.com/vechain/thor/v2/state"
"github.com/vechain/thor/v2/thor"
"github.com/vechain/thor/v2/txpool"
cli "gopkg.in/urfave/cli.v1"
"gopkg.in/urfave/cli.v1"

// Force-load the tracer engines to trigger registration
_ "github.com/vechain/thor/v2/tracers/js"
Expand Down Expand Up @@ -355,7 +355,7 @@ func masterKeyAction(ctx *cli.Context) error {
if isatty.IsTerminal(os.Stdin.Fd()) {
fmt.Println("Input JSON keystore (end with ^d):")
}
keyjson, err := ioutil.ReadAll(os.Stdin)
keyjson, err := io.ReadAll(os.Stdin)

Check failure on line 358 in cmd/thor/main.go

View workflow job for this annotation

GitHub Actions / golangci-lint

assignments should only be cuddled with other assignments (wsl)
if err != nil {
return err
}
Expand Down
11 changes: 5 additions & 6 deletions cmd/thor/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ import (
"encoding/json"
"fmt"
"io"
"io/ioutil"
"math"
"net"
"net/http"
Expand All @@ -34,7 +33,7 @@ import (
"github.com/ethereum/go-ethereum/p2p/nat"
"github.com/ethereum/go-ethereum/rlp"
"github.com/inconshreveable/log15"
tty "github.com/mattn/go-tty"
"github.com/mattn/go-tty"

Check failure on line 36 in cmd/thor/utils.go

View workflow job for this annotation

GitHub Actions / golangci-lint

import 'github.com/mattn/go-tty' is not allowed from list 'Main' (depguard)
"github.com/pkg/errors"
"github.com/vechain/thor/v2/api/doc"
"github.com/vechain/thor/v2/chain"
Expand All @@ -49,7 +48,7 @@ import (
"github.com/vechain/thor/v2/thor"
"github.com/vechain/thor/v2/tx"
"github.com/vechain/thor/v2/txpool"
cli "gopkg.in/urfave/cli.v1"
"gopkg.in/urfave/cli.v1"
)

func initLogger(ctx *cli.Context) {
Expand Down Expand Up @@ -146,7 +145,7 @@ func handleXGenesisID(h http.Handler, genesisID thor.Bytes32) http.Handler {
}
w.Header().Set(headerKey, expectedID)
if actualID != "" && actualID != expectedID {
io.Copy(ioutil.Discard, r.Body)
io.Copy(io.Discard, r.Body)

Check failure on line 148 in cmd/thor/utils.go

View workflow job for this annotation

GitHub Actions / golangci-lint

Error return value of `io.Copy` is not checked (errcheck)
http.Error(w, "genesis id mismatch", http.StatusForbidden)
return
}
Expand Down Expand Up @@ -445,7 +444,7 @@ func newP2PComm(ctx *cli.Context, repo *chain.Repository, txPool *txpool.TxPool,

peersCachePath := filepath.Join(instanceDir, "peers.cache")

if data, err := ioutil.ReadFile(peersCachePath); err != nil {
if data, err := os.ReadFile(peersCachePath); err != nil {
if !os.IsNotExist(err) {
log.Warn("failed to load peers cache", "err", err)
}
Expand Down Expand Up @@ -500,7 +499,7 @@ func (p *p2pComm) Stop() {
log.Warn("failed to encode cached peers", "err", err)
return
}
if err := ioutil.WriteFile(p.peersCachePath, data, 0600); err != nil {
if err := os.WriteFile(p.peersCachePath, data, 0600); err != nil {

Check failure on line 502 in cmd/thor/utils.go

View workflow job for this annotation

GitHub Actions / golangci-lint

File is not `gofumpt`-ed (gofumpt)
log.Warn("failed to write peers cache", "err", err)
}
}
Expand Down
3 changes: 1 addition & 2 deletions p2psrv/bootstrap_nodes.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import (
"context"
"fmt"
"io"
"io/ioutil"
"net/http"

"github.com/ethereum/go-ethereum/p2p/discv5"
Expand All @@ -22,7 +21,7 @@ func fetchRemoteBootstrapNodes(ctx context.Context, remoteURL string) ([]*discv5
return nil, err
}
defer resp.Body.Close()
defer io.Copy(ioutil.Discard, resp.Body)
defer io.Copy(io.Discard, resp.Body)

Check failure on line 24 in p2psrv/bootstrap_nodes.go

View workflow job for this annotation

GitHub Actions / golangci-lint

Error return value of `io.Copy` is not checked (errcheck)

if resp.StatusCode != http.StatusOK {
return nil, fmt.Errorf("http fetch failed: statusCode=%d", resp.StatusCode)
Expand Down
3 changes: 1 addition & 2 deletions txpool/blocklist.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ import (
"context"
"fmt"
"io"
"io/ioutil"
"net/http"
"os"
"strings"
Expand Down Expand Up @@ -83,7 +82,7 @@ func (bl *blocklist) Fetch(ctx context.Context, url string, eTag *string) error
return err
}
defer resp.Body.Close()
defer io.Copy(ioutil.Discard, resp.Body)
defer io.Copy(io.Discard, resp.Body)

Check failure on line 85 in txpool/blocklist.go

View workflow job for this annotation

GitHub Actions / golangci-lint

Error return value of `io.Copy` is not checked (errcheck)

if resp.StatusCode == http.StatusNotModified {
return nil
Expand Down
2 changes: 2 additions & 0 deletions vm/bn256/cloudflare/optate.go
Original file line number Diff line number Diff line change
Expand Up @@ -199,8 +199,10 @@ func miller(q *twistPoint, p *curvePoint) *gfP12 {
r = newR

r2.Square(&minusQ2.y)
//nolint: staticcheck
a, b, c, newR = lineFunctionAdd(r, minusQ2, bAffine, r2)
mulLine(ret, a, b, c)
//nolint: staticcheck
r = newR

return ret
Expand Down
3 changes: 2 additions & 1 deletion vm/contracts.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import (
"github.com/ethereum/go-ethereum/common/math"
"github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/params"
// nolint:staticcheck

Check failure on line 29 in vm/contracts.go

View workflow job for this annotation

GitHub Actions / golangci-lint

File is not `gci`-ed with --skip-generated -s standard -s default (gci)
"golang.org/x/crypto/ripemd160"

"github.com/vechain/thor/v2/blake2b"
Expand Down Expand Up @@ -473,7 +474,7 @@ func (c *blake2F) Run(input []byte) ([]byte, error) {
// Parse the input into the Blake2b call parameters
var (
rounds = binary.BigEndian.Uint32(input[0:4])
final = (input[212] == blake2FFinalBlockBytes)
final = input[212] == blake2FFinalBlockBytes

h [8]uint64
m [16]uint64
Expand Down

0 comments on commit 10b09c1

Please sign in to comment.