summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/go-xorm/xorm/.drone.yml
blob: df9d405bc29266bbcecba459eabb26d9d360b41c (plain)
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
workspace:
  base: /go
  path: src/github.com/go-xorm/xorm

clone:
  git:
    image: plugins/git:next
    depth: 50
    tags: true

services:
  mysql:
    image: mysql:5.7
    environment:
      - MYSQL_DATABASE=xorm_test
      - MYSQL_ALLOW_EMPTY_PASSWORD=yes
    when:
      event: [ push, tag, pull_request ]

  pgsql:
    image: postgres:9.5
    environment:
      - POSTGRES_USER=postgres
      - POSTGRES_DB=xorm_test
    when:
      event: [ push, tag, pull_request ]

  #mssql:
  #  image: microsoft/mssql-server-linux:2017-CU11
  #  environment:
  #    - ACCEPT_EULA=Y
  #    - SA_PASSWORD=yourStrong(!)Password
  #    - MSSQL_PID=Developer
  #  commands:
  #    - echo 'CREATE DATABASE xorm_test' > create.sql
  #    - /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P yourStrong(!)Password -i "create.sql"

matrix:
  GO_VERSION:
    - 1.8
    - 1.9
    - 1.10
    - 1.11

pipeline:
  init_postgres:
    image: postgres:9.5
    commands:
      # wait for postgres service to become available
      - |
        until psql -U postgres -d xorm_test -h pgsql \
         -c "SELECT 1;" >/dev/null 2>&1; do sleep 1; done
      # query the database
      - |
        psql -U postgres -d xorm_test -h pgsql \
          -c "create schema xorm;"

  build:
    image: golang:${GO_VERSION}
    commands:
      - go get -t -d -v ./...
      - go get -u xorm.io/core
      - go get -u xorm.io/builder
      - go build -v
    when:
      event: [ push, pull_request ]

  test-sqlite:
    image: golang:${GO_VERSION}
    commands:
      - go get -u github.com/wadey/gocovmerge
      - go test -v -race -db="sqlite3" -conn_str="./test.db" -coverprofile=coverage1-1.txt -covermode=atomic
      - go test -v -race -db="sqlite3" -conn_str="./test.db" -cache=true -coverprofile=coverage1-2.txt -covermode=atomic
    when:
      event: [ push, pull_request ]

  test-mysql:
    image: golang:${GO_VERSION}
    commands:
      - go test -v -race -db="mysql" -conn_str="root:@tcp(mysql)/xorm_test" -coverprofile=coverage2-1.txt -covermode=atomic
      - go test -v -race -db="mysql" -conn_str="root:@tcp(mysql)/xorm_test" -cache=true -coverprofile=coverage2-2.txt -covermode=atomic
    when:
      event: [ push, pull_request ]

  test-mysql-utf8mb4:
    image: golang:${GO_VERSION}
    commands:
      - go test -v -race -db="mysql" -conn_str="root:@tcp(mysql)/xorm_test?charset=utf8mb4" -coverprofile=coverage2.1-1.txt -covermode=atomic
      - go test -v -race -db="mysql" -conn_str="root:@tcp(mysql)/xorm_test?charset=utf8mb4" -cache=true -coverprofile=coverage2.1-2.txt -covermode=atomic
    when:
      event: [ push, pull_request ]

  test-mymysql:
    image: golang:${GO_VERSION}
    commands:
      - go test -v -race -db="mymysql" -conn_str="tcp:mysql:3306*xorm_test/root/" -coverprofile=coverage3-1.txt -covermode=atomic
      - go test -v -race -db="mymysql" -conn_str="tcp:mysql:3306*xorm_test/root/" -cache=true -coverprofile=coverage3-2.txt -covermode=atomic
    when:
      event: [ push, pull_request ]

  test-postgres:
    image: golang:${GO_VERSION}
    commands:
      - go test -v -race -db="postgres" -conn_str="postgres://postgres:@pgsql/xorm_test?sslmode=disable" -coverprofile=coverage4-1.txt -covermode=atomic
      - go test -v -race -db="postgres" -conn_str="postgres://postgres:@pgsql/xorm_test?sslmode=disable" -cache=true -coverprofile=coverage4-2.txt -covermode=atomic
    when:
      event: [ push, pull_request ]
  
  test-postgres-schema:
    image: golang:${GO_VERSION}
    commands:
      - go test -v -race -db="postgres" -conn_str="postgres://postgres:@pgsql/xorm_test?sslmode=disable" -schema=xorm -coverprofile=coverage5-1.txt -covermode=atomic
      - go test -v -race -db="postgres" -conn_str="postgres://postgres:@pgsql/xorm_test?sslmode=disable" -schema=xorm -cache=true -coverprofile=coverage5-2.txt -covermode=atomic
      - gocovmerge coverage1-1.txt coverage1-2.txt coverage2-1.txt coverage2-2.txt coverage2.1-1.txt coverage2.1-2.txt coverage3-1.txt coverage3-2.txt coverage4-1.txt coverage4-2.txt coverage5-1.txt coverage5-2.txt > coverage.txt
    when:
      event: [ push, pull_request ]

  #coverage:
  #  image: robertstettner/drone-codecov
  #  secrets: [ codecov_token ]
  #  files:
  #    - coverage.txt
  #  when:
  #    event: [ push, pull_request ]
  #    branch: [ master ]