Skip to content
This repository has been archived by the owner on Dec 5, 2024. It is now read-only.

Commit

Permalink
Migrate to cobra (issue #46)
Browse files Browse the repository at this point in the history
Closes #46
  • Loading branch information
pcantera committed Oct 11, 2022
1 parent 1f5b1c1 commit 87ae0a4
Show file tree
Hide file tree
Showing 474 changed files with 22,515 additions and 52,318 deletions.
29 changes: 29 additions & 0 deletions .goreleaser.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
# This is an example .goreleaser.yml file with some sensible defaults.
# Make sure to check the documentation at https://goreleaser.com
before:
hooks:
# You may remove this if you don't use go modules.
- go mod tidy
builds:
- binary: cio
env:
- CGO_ENABLED=0
goos:
- windows
- darwin
- linux
goarch:
- amd64
- arm64
archives:
- format: binary
name_template: "{{ .ProjectName }}.{{ .Version }}.{{ .Arch }}.{{ .Os }}"
checksum:
name_template: '{{ .ProjectName }}_{{ .Version }}_checksums.txt'
release:
prerelease: auto
name_template: "{{.ProjectName}} {{.Tag}}"
snapshot:
name_template: "{{ incpatch .Version }}-next"
changelog:
sort: asc
16 changes: 0 additions & 16 deletions .goreleaser.yml

This file was deleted.

14 changes: 0 additions & 14 deletions .travis.yml

This file was deleted.

37 changes: 0 additions & 37 deletions agentsecret/agentsecret.go

This file was deleted.

42 changes: 0 additions & 42 deletions api/agentsecret/secret_api.go

This file was deleted.

55 changes: 0 additions & 55 deletions api/agentsecret/secret_api_mocked.go

This file was deleted.

10 changes: 0 additions & 10 deletions api/agentsecret/secret_api_test.go

This file was deleted.

31 changes: 31 additions & 0 deletions api/api_client_audit.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
// Copyright (c) 2017-2022 Ingram Micro Inc.

package api

import (
"github.com/ingrammicro/cio/logger"
"github.com/ingrammicro/cio/types"
"golang.org/x/net/context"
)

// ListEvents returns the list of events as an array of Event
func (imco *ClientAPI) ListEvents(ctx context.Context) (events []*types.Event, err error) {
logger.DebugFuncInfo()

_, err = imco.GetAndCheck(ctx, pathAuditEvents, true, &events)
if err != nil {
return nil, err
}
return events, nil
}

// ListSysEvents returns the list of events as an array of Event
func (imco *ClientAPI) ListSysEvents(ctx context.Context) (events []*types.Event, err error) {
logger.DebugFuncInfo()

_, err = imco.GetAndCheck(ctx, pathAuditSystemEvents, true, &events)
if err != nil {
return nil, err
}
return events, nil
}
92 changes: 92 additions & 0 deletions api/api_client_audit_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
package api

import (
"context"
"fmt"
"github.com/ingrammicro/cio/types"
"net/http"
"net/http/httptest"
"reflect"
"strings"
"testing"
)

func TestListEvents(t *testing.T) {
tests := map[string]struct {
expected interface{}
server *httptest.Server
}{
"if defined endpoint for API service is resolving properly": {
expected: []*types.Event{},
server: NewServer(http.StatusOK, []*types.Event{}),
},
"if defined endpoint for API service is invalid or cannot be reached": {
expected: "Cannot execute request",
server: nil,
},
}

config, svc, err := InitConfigAndClientAPI()
if err != nil {
t.Errorf("Unexpected error: %v\n", err)
return
}

for title, test := range tests {
t.Run(title, func(t *testing.T) {
if test.server != nil {
server := test.server
defer server.Close()
config.APIEndpoint = server.URL
}

events, err := svc.ListEvents(context.Background())
if err != nil && !strings.Contains(err.Error(), fmt.Sprintf("%s", test.expected)) {
t.Errorf("Unexpected error: %v\n", err)
}
if err == nil && !reflect.DeepEqual(events, test.expected) {
t.Errorf("Unexpected response: %v\n", events)
}
})
}
}

func TestListSysEvents(t *testing.T) {
tests := map[string]struct {
expected interface{}
server *httptest.Server
}{
"if defined endpoint for API service is resolving properly": {
expected: []*types.Event{},
server: NewServer(http.StatusOK, []*types.Event{}),
},
"if defined endpoint for API service is invalid or cannot be reached": {
expected: "Cannot execute request",
server: nil,
},
}

config, svc, err := InitConfigAndClientAPI()
if err != nil {
t.Errorf("Unexpected error: %v\n", err)
return
}

for title, test := range tests {
t.Run(title, func(t *testing.T) {
if test.server != nil {
server := test.server
defer server.Close()
config.APIEndpoint = server.URL
}

events, err := svc.ListSysEvents(context.Background())
if err != nil && !strings.Contains(err.Error(), fmt.Sprintf("%s", test.expected)) {
t.Errorf("Unexpected error: %v\n", err)
}
if err == nil && !reflect.DeepEqual(events, test.expected) {
t.Errorf("Unexpected response: %v\n", events)
}
})
}
}
Loading

0 comments on commit 87ae0a4

Please sign in to comment.