0
mirror of https://github.com/valentineus/go-metatrader4.git synced 2025-06-08 10:13:33 +03:00

Added GitHub Actions (#4)

This commit is contained in:
Valentin Popov 2025-06-04 13:09:26 +04:00 committed by GitHub
parent 7240595478
commit b57c1a6878
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 70 additions and 12 deletions

52
.github/workflows/ci.yml vendored Normal file
View File

@ -0,0 +1,52 @@
name: CI
on:
push:
branches: [ master ]
pull_request:
branches: [ master ]
jobs:
test:
name: Test
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version: '1.24.2'
- name: Cache Go modules
uses: actions/cache@v4
with:
path: |
~/.cache/go-build
~/go/pkg/mod
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-
- name: Download dependencies
run: go mod download
- name: Verify dependencies
run: go mod verify
- name: Run go vet
run: go vet ./...
- name: Run tests
run: go test -race -coverprofile=coverage.out -covermode=atomic ./...
lint:
name: Lint
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version: '1.24.2'
- name: Run golangci-lint
uses: golangci/golangci-lint-action@v8
with:
version: latest
args: --timeout=5m

View File

@ -32,9 +32,13 @@ func (c *Conn) Close() error {
func (c *Conn) Send(ctx context.Context, data []byte, timeout time.Duration) error { func (c *Conn) Send(ctx context.Context, data []byte, timeout time.Duration) error {
if dl, ok := ctx.Deadline(); ok { if dl, ok := ctx.Deadline(); ok {
c.netConn.SetWriteDeadline(dl) if err := c.netConn.SetWriteDeadline(dl); err != nil {
return err
}
} else { } else {
c.netConn.SetWriteDeadline(time.Now().Add(timeout)) if err := c.netConn.SetWriteDeadline(time.Now().Add(timeout)); err != nil {
return err
}
} }
_, err := c.netConn.Write(data) _, err := c.netConn.Write(data)
return err return err
@ -42,9 +46,13 @@ func (c *Conn) Send(ctx context.Context, data []byte, timeout time.Duration) err
func (c *Conn) Receive(ctx context.Context, timeout time.Duration) ([]byte, error) { func (c *Conn) Receive(ctx context.Context, timeout time.Duration) ([]byte, error) {
if dl, ok := ctx.Deadline(); ok { if dl, ok := ctx.Deadline(); ok {
c.netConn.SetReadDeadline(dl) if err := c.netConn.SetReadDeadline(dl); err != nil {
return nil, err
}
} else { } else {
c.netConn.SetReadDeadline(time.Now().Add(timeout)) if err := c.netConn.SetReadDeadline(time.Now().Add(timeout)); err != nil {
return nil, err
}
} }
return io.ReadAll(c.netConn) return io.ReadAll(c.netConn)
} }

View File

@ -3,7 +3,6 @@ package mt4
import ( import (
"context" "context"
"fmt" "fmt"
"net"
"time" "time"
"go.popov.link/metatrader4/internal/conn" "go.popov.link/metatrader4/internal/conn"
@ -18,7 +17,6 @@ type Client struct {
readTimeout time.Duration readTimeout time.Duration
writeTimeout time.Duration writeTimeout time.Duration
autoClose bool autoClose bool
dialer net.Dialer
c *conn.Conn c *conn.Conn
} }
@ -86,7 +84,7 @@ func (c *Client) Execute(ctx context.Context, command string, params map[string]
encoded, err := proto.EncodeParams(params) encoded, err := proto.EncodeParams(params)
if err != nil { if err != nil {
if c.autoClose { if c.autoClose {
c.Close() _ = c.Close()
} }
return "", err return "", err
} }
@ -94,14 +92,14 @@ func (c *Client) Execute(ctx context.Context, command string, params map[string]
if err := c.c.Send(ctx, req, c.writeTimeout); err != nil { if err := c.c.Send(ctx, req, c.writeTimeout); err != nil {
if c.autoClose { if c.autoClose {
c.Close() _ = c.Close()
} }
return "", fmt.Errorf("send: %w", err) return "", fmt.Errorf("send: %w", err)
} }
respBytes, err := c.c.Receive(ctx, c.readTimeout) respBytes, err := c.c.Receive(ctx, c.readTimeout)
if c.autoClose { if c.autoClose {
c.Close() _ = c.Close()
} }
if err != nil { if err != nil {
return "", fmt.Errorf("receive: %w", err) return "", fmt.Errorf("receive: %w", err)

View File

@ -15,10 +15,10 @@ import (
func mockServer(response string) (net.Conn, net.Conn) { func mockServer(response string) (net.Conn, net.Conn) {
server, client := net.Pipe() server, client := net.Pipe()
go func() { go func() {
defer server.Close() defer func() { _ = server.Close() }()
buf := make([]byte, 1024) buf := make([]byte, 1024)
server.Read(buf) // read request ignoring _, _ = server.Read(buf) // read request ignoring
server.Write([]byte(response)) _, _ = server.Write([]byte(response))
}() }()
return client, server return client, server
} }