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:
parent
7240595478
commit
b57c1a6878
52
.github/workflows/ci.yml
vendored
Normal file
52
.github/workflows/ci.yml
vendored
Normal 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
|
@ -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)
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user