mirror of https://github.com/statping/statping
travis
parent
db872ad767
commit
80cf8d7ac3
85
.travis.yml
85
.travis.yml
|
@ -1,62 +1,61 @@
|
||||||
os:
|
after_success:
|
||||||
- linux
|
- "if [[ \"$TRAVIS_BRANCH\" == \"master\" && \"$TRAVIS_PULL_REQUEST\" = \"false\" ]]; then make travis-build; fi"
|
||||||
language: go
|
before_install:
|
||||||
go: 1.14
|
- "rm -rf ~/.nvm && git clone https://github.com/creationix/nvm.git ~/.nvm && (cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`) && source ~/.nvm/nvm.sh && nvm install stable"
|
||||||
go_import_path: github.com/statping/statping
|
- "nvm install 10.17.0"
|
||||||
|
- "nvm use 10.17.0 --default"
|
||||||
|
before_script:
|
||||||
|
- "mysql -e 'CREATE DATABASE IF NOT EXISTS test;'"
|
||||||
|
- "psql -c 'create database test;' -U postgres"
|
||||||
|
branches:
|
||||||
|
only:
|
||||||
|
- master
|
||||||
cache:
|
cache:
|
||||||
directories:
|
directories:
|
||||||
- "~/.npm"
|
- ~/.npm
|
||||||
- "~/.cache"
|
- ~/.cache
|
||||||
- "$GOPATH/src/github.com/statping/statping/frontend/node_modules"
|
- $GOPATH/src/github.com/statping/statping/frontend/node_modules
|
||||||
- "$GOPATH/src/github.com/statping/statping/vendor"
|
- $GOPATH/src/github.com/statping/statping/vendor
|
||||||
sudo: required
|
|
||||||
services:
|
|
||||||
- docker
|
|
||||||
- postgresql
|
|
||||||
- mysql
|
|
||||||
- mongodb
|
|
||||||
env:
|
env:
|
||||||
global:
|
global:
|
||||||
- PATH=$HOME/.local/bin:$PATH
|
- "PATH=$HOME/.local/bin:$PATH"
|
||||||
- DB_HOST=localhost
|
- DB_HOST=localhost
|
||||||
- DB_USER=travis
|
- DB_USER=travis
|
||||||
- DB_PASS=
|
- DB_PASS=
|
||||||
- DB_DATABASE=test
|
- DB_DATABASE=test
|
||||||
- GO_ENV=test
|
- GO_ENV=test
|
||||||
- STATPING_DIR=$GOPATH/src/github.com/statping/statping
|
- STATPING_DIR=$GOPATH/src/github.com/statping/statping
|
||||||
|
go: 1.14
|
||||||
|
go_import_path: github.com/statping/statping
|
||||||
|
install:
|
||||||
|
- "npm install -g sass"
|
||||||
|
- "npm install -g newman"
|
||||||
|
- "npm install -g cross-env"
|
||||||
|
- "pip install --user awscli"
|
||||||
|
- "go mod vendor"
|
||||||
|
- "make test-deps yarn clean compile install"
|
||||||
|
language: go
|
||||||
matrix:
|
matrix:
|
||||||
allow_failures:
|
allow_failures:
|
||||||
- go: master
|
-
|
||||||
|
go: master
|
||||||
fast_finish: true
|
fast_finish: true
|
||||||
notifications:
|
notifications:
|
||||||
email: true
|
email: true
|
||||||
branches:
|
os:
|
||||||
only:
|
- linux
|
||||||
- master
|
|
||||||
before_install:
|
|
||||||
- rm -rf ~/.nvm && git clone https://github.com/creationix/nvm.git ~/.nvm && (cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`) && source ~/.nvm/nvm.sh && nvm install stable
|
|
||||||
- nvm install 10.17.0
|
|
||||||
- nvm use 10.17.0 --default
|
|
||||||
install:
|
|
||||||
- npm install -g sass
|
|
||||||
- npm install -g newman
|
|
||||||
- npm install -g cross-env
|
|
||||||
- pip install --user awscli
|
|
||||||
- go mod vendor
|
|
||||||
- make test-deps yarn clean compile install
|
|
||||||
before_script:
|
|
||||||
- mysql -e 'CREATE DATABASE IF NOT EXISTS test;'
|
|
||||||
- psql -c 'create database test;' -U postgres
|
|
||||||
script:
|
script:
|
||||||
- travis_retry make clean test-ci
|
- "travis_retry make clean test-ci"
|
||||||
- if [[ "$TRAVIS_BRANCH" == "master" && "$TRAVIS_PULL_REQUEST" = "false" ]]; then
|
- "if [[ \"$TRAVIS_BRANCH\" == \"master\" && \"$TRAVIS_PULL_REQUEST\" = \"false\" ]]; then make coverage; fi"
|
||||||
make coverage; fi
|
services:
|
||||||
after_success:
|
- docker
|
||||||
- if [[ "$TRAVIS_BRANCH" == "master" && "$TRAVIS_PULL_REQUEST" = "false" ]]; then
|
- postgresql
|
||||||
make travis-build; fi
|
- mysql
|
||||||
|
- mongodb
|
||||||
|
sudo: required
|
||||||
webhooks:
|
webhooks:
|
||||||
urls:
|
|
||||||
- "$GITTER"
|
|
||||||
on_success: change
|
|
||||||
on_failure: always
|
on_failure: always
|
||||||
on_start: never
|
on_start: never
|
||||||
|
on_success: change
|
||||||
|
urls:
|
||||||
|
- $GITTER
|
||||||
|
|
|
@ -3,23 +3,42 @@ package groups
|
||||||
import (
|
import (
|
||||||
"github.com/statping/statping/database"
|
"github.com/statping/statping/database"
|
||||||
"github.com/statping/statping/types/null"
|
"github.com/statping/statping/types/null"
|
||||||
|
"github.com/statping/statping/types/services"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
var example = &Group{
|
var example = &Group{
|
||||||
|
Id: 1,
|
||||||
Name: "Example Group",
|
Name: "Example Group",
|
||||||
Public: null.NewNullBool(true),
|
Public: null.NewNullBool(true),
|
||||||
Order: 1,
|
Order: 1,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var s1 = &services.Service{
|
||||||
|
Name: "Example Service",
|
||||||
|
Public: null.NewNullBool(true),
|
||||||
|
Order: 1,
|
||||||
|
GroupId: 1,
|
||||||
|
}
|
||||||
|
|
||||||
|
var s2 = &services.Service{
|
||||||
|
Name: "Example Service 2",
|
||||||
|
Public: null.NewNullBool(true),
|
||||||
|
Order: 2,
|
||||||
|
GroupId: 1,
|
||||||
|
}
|
||||||
|
|
||||||
func TestInit(t *testing.T) {
|
func TestInit(t *testing.T) {
|
||||||
db, err := database.OpenTester()
|
db, err := database.OpenTester()
|
||||||
require.Nil(t, err)
|
require.Nil(t, err)
|
||||||
db.CreateTable(&Group{})
|
db.CreateTable(&Group{}, &services.Service{})
|
||||||
db.Create(&example)
|
db.Create(&example)
|
||||||
|
db.Create(&s1)
|
||||||
|
db.Create(&s2)
|
||||||
SetDB(db)
|
SetDB(db)
|
||||||
|
services.SetDB(db)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFind(t *testing.T) {
|
func TestFind(t *testing.T) {
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
package groups
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/statping/statping/types/services"
|
|
||||||
)
|
|
||||||
|
|
||||||
func (g *Group) Services() []*services.Service {
|
|
||||||
var services []*services.Service
|
|
||||||
db.Where("group = ?", g.Id).Find(&services)
|
|
||||||
return services
|
|
||||||
}
|
|
||||||
|
|
||||||
// GroupOrder will reorder the groups based on 'order_id' (Order)
|
|
||||||
type GroupOrder []*Group
|
|
||||||
|
|
||||||
// Sort interface for resorting the Groups in order
|
|
||||||
func (c GroupOrder) Len() int { return len(c) }
|
|
||||||
func (c GroupOrder) Swap(i, j int) { c[i], c[j] = c[j], c[i] }
|
|
||||||
func (c GroupOrder) Less(i, j int) bool { return c[i].Order < c[j].Order }
|
|
|
@ -14,3 +14,11 @@ type Group struct {
|
||||||
CreatedAt time.Time `gorm:"column:created_at" json:"created_at"`
|
CreatedAt time.Time `gorm:"column:created_at" json:"created_at"`
|
||||||
UpdatedAt time.Time `gorm:"column:updated_at" json:"updated_at"`
|
UpdatedAt time.Time `gorm:"column:updated_at" json:"updated_at"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GroupOrder will reorder the groups based on 'order_id' (Order)
|
||||||
|
type GroupOrder []*Group
|
||||||
|
|
||||||
|
// Sort interface for resorting the Groups in order
|
||||||
|
func (c GroupOrder) Len() int { return len(c) }
|
||||||
|
func (c GroupOrder) Swap(i, j int) { c[i], c[j] = c[j], c[i] }
|
||||||
|
func (c GroupOrder) Less(i, j int) bool { return c[i].Order < c[j].Order }
|
||||||
|
|
Loading…
Reference in New Issue