Skip to content

Commit

Permalink
improve coverage
Browse files Browse the repository at this point in the history
  • Loading branch information
jbsv committed Nov 17, 2023
1 parent b8bdc6b commit 3238ee3
Show file tree
Hide file tree
Showing 3 changed files with 141 additions and 7 deletions.
6 changes: 2 additions & 4 deletions .github/workflows/server_test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ name: Server test

on:
push:
branches: [ main ]
pull_request:
types: [opened, synchronize, reopened]

Expand All @@ -27,8 +26,7 @@ jobs:
- name: Set up Go 1.21
uses: actions/setup-go@v4
with:
go-version: "1.21"
cache: false
go-version: "=1.21"

- name: Test without coverage
if: matrix.platform == 'macos-latest' || matrix.platform == 'windows-latest'
Expand All @@ -38,7 +36,7 @@ jobs:
if: matrix.platform == 'ubuntu-latest'
run: make coverage

- name: Run code analysis
- name: Sonarcloud scan
if: matrix.platform == 'ubuntu-latest'
uses: SonarSource/sonarcloud-github-action@master
with:
Expand Down
140 changes: 138 additions & 2 deletions server/blockchain/calypso/calypso_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,44 @@ import (
"go.dedis.ch/dela/testing/fake"
)

func TestExecute(t *testing.T) {
func Test_secretSet_addSecret(t *testing.T) {
s := secretSet{}
secret := "some secret"

s.addSecret(secret)

require.Equal(t, 1, len(s))
require.Equal(t, struct{}{}, s[secret])
}

func Test_NewCreds(t *testing.T) {
creds := NewCreds()

require.NotNilf(t, creds, "creds should not be nil")
}

func Test_RegisterContract(_ *testing.T) {
RegisterContract(native.NewExecution(), Contract{})
}

func Test_NewContract(t *testing.T) {
contract := NewContract(fakeAccess{})

require.NotNilf(t, contract, "contract should not be nil")
require.NotNilf(t, contract.secrets, "secrets should not be nil")
require.NotNilf(t, contract.printer, "printer should not be nil")
require.NotNilf(t, contract.cmd, "cmd should not be nil")
require.NotNilf(t, contract.access, "access should not be nil")
}

func TestContract_UID(t *testing.T) {
contract := NewContract(fakeAccess{})

require.NotNilf(t, contract, "contract should not be nil")
require.Equal(t, ContractUID, contract.UID())
}

func TestExecuteFailing(t *testing.T) {
contract := NewContract(fakeAccess{err: fake.GetError()})

err := contract.Execute(fakeStore{}, makeStep(t))
Expand All @@ -39,12 +76,49 @@ func TestExecute(t *testing.T) {
err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "LIST_SMC"))
require.EqualError(t, err, fake.Err("failed to LIST_SMC"))

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "CREATE_SECRET"))
require.EqualError(t, err, fake.Err("failed to CREATE_SECRET"))

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "LIST_SECRETS"))
require.EqualError(t, err, fake.Err("failed to LIST_SECRETS"))

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "REVEAL_SECRET"))
require.EqualError(t, err, fake.Err("failed to REVEAL_SECRET"))

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "LIST_AUDIT_LOG"))
require.EqualError(t, err, fake.Err("failed to LIST_AUDIT_LOG"))

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "fake"))
require.EqualError(t, err, "unknown command: fake")
}

func TestExecutePassing(t *testing.T) {
contract := NewContract(fakeAccess{})
contract.cmd = fakeCmd{}
err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "ADVERTISE_SMC"))

err := contract.Execute(fakeStore{}, makeStep(t, CmdArg, "ADVERTISE_SMC"))
require.NoError(t, err)

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "DELETE_SMC"))
require.NoError(t, err)

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "LIST_SMC"))
require.NoError(t, err)

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "CREATE_SECRET"))
require.NoError(t, err)

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "LIST_SECRETS"))
require.NoError(t, err)

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "REVEAL_SECRET"))
require.NoError(t, err)

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "LIST_AUDIT_LOG"))
require.NoError(t, err)

err = contract.Execute(fakeStore{}, makeStep(t, CmdArg, "fake"))
require.EqualError(t, err, "unknown command: fake")
}

func TestCommand_AdvertiseSmc(t *testing.T) {
Expand Down Expand Up @@ -524,6 +598,68 @@ func TestRegisterContract(_ *testing.T) {
RegisterContract(native.NewExecution(), Contract{})
}

func Test_validateRosterUpdate(t *testing.T) {
type args struct {
oldRoster []byte
newRoster []byte
}
tests := []struct {
name string
args args
wantErr bool
}{
{
name: "validateNew",
args: args{
oldRoster: []byte(""),
newRoster: []byte("node:12345"),
},
wantErr: true,
},
{
name: "validateAdd",
args: args{
oldRoster: []byte("node:12345"),
newRoster: []byte("node:12345,other:54321"),
},
wantErr: false,
},
{
name: "validateNoChange",
args: args{
oldRoster: []byte("node:12345"),
newRoster: []byte("node:12345"),
},
wantErr: false,
},
{
name: "validateRemove",
args: args{
oldRoster: []byte("node:12345,other:54321"),
newRoster: []byte("node:12345"),
},
wantErr: true,
},
{
name: "validateNoOverlap",
args: args{
oldRoster: []byte("node:12345"),
newRoster: []byte("other:54321"),
},
wantErr: true,
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if err := validateRosterUpdate(tt.args.oldRoster,
tt.args.newRoster); (err != nil) != tt.wantErr {
t.Errorf("validateRosterUpdate() error = %v, wantErr %v", err, tt.wantErr)
}
})
}
}

// -----------------------------------------------------------------------------
// Utility functions

Expand Down
2 changes: 1 addition & 1 deletion server/sonar-project.properties
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ sonar.projectKey=hbt-server

# Path of the test and coverage reports
sonar.go.tests.reportPaths=./report.json
sonar.go.coverage.reportPaths=./coverage.out
sonar.go.coverage.reportPaths=./profile.cov

# Path patterns of the source files
sonar.sources=.
Expand Down

0 comments on commit 3238ee3

Please sign in to comment.