mirror of
https://github.com/ultravioletrs/cocos.git
synced 2026-06-22 20:00:18 +00:00
46b94204df
* improve file streaming Signed-off-by: Sammy Oina <sammyoina@gmail.com> * error check Signed-off-by: Sammy Oina <sammyoina@gmail.com> * empty line Signed-off-by: Sammy Oina <sammyoina@gmail.com> * fix tests Signed-off-by: Sammy Oina <sammyoina@gmail.com> * send buffer test Signed-off-by: Sammy Oina <sammyoina@gmail.com> * fix test cases Signed-off-by: Sammy Oina <sammyoina@gmail.com> * stream data and attestation Signed-off-by: Sammy Oina <sammyoina@gmail.com> * fumpt Signed-off-by: Sammy Oina <sammyoina@gmail.com> * fix test Signed-off-by: Sammy Oina <sammyoina@gmail.com> * mocks Signed-off-by: Sammy Oina <sammyoina@gmail.com> * value check Signed-off-by: Sammy Oina <sammyoina@gmail.com> * more value checks Signed-off-by: Sammy Oina <sammyoina@gmail.com> * add test cases Signed-off-by: Sammy Oina <sammyoina@gmail.com> * fumpt Signed-off-by: Sammy Oina <sammyoina@gmail.com> * fix tests Signed-off-by: Sammy Oina <sammyoina@gmail.com> * all files Signed-off-by: Sammy Oina <sammyoina@gmail.com> * fix lint Signed-off-by: Sammy Oina <sammyoina@gmail.com> --------- Signed-off-by: Sammy Oina <sammyoina@gmail.com>
178 lines
4.6 KiB
Go
178 lines
4.6 KiB
Go
// Copyright (c) Ultraviolet
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package cli
|
|
|
|
import (
|
|
"bytes"
|
|
"errors"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/mock"
|
|
"github.com/stretchr/testify/require"
|
|
"github.com/ultravioletrs/cocos/pkg/sdk/mocks"
|
|
)
|
|
|
|
const compResult = "Test computation result"
|
|
|
|
func TestResultsCmd_MultipleExecutions(t *testing.T) {
|
|
mockSDK := new(mocks.SDK)
|
|
mockSDK.On("Result", mock.Anything, mock.Anything, mock.Anything).Return(nil).Run(func(args mock.Arguments) {
|
|
_, err := args.Get(2).(*os.File).WriteString(compResult)
|
|
require.NoError(t, err)
|
|
})
|
|
testCLI := CLI{agentSDK: mockSDK}
|
|
|
|
err := generateRSAPrivateKeyFile(privateKeyFile)
|
|
require.NoError(t, err)
|
|
|
|
cmd := testCLI.NewResultsCmd()
|
|
buf := new(bytes.Buffer)
|
|
cmd.SetOut(buf)
|
|
cmd.SetArgs([]string{privateKeyFile})
|
|
|
|
for i := 0; i < 3; i++ {
|
|
err = cmd.Execute()
|
|
require.NoError(t, err)
|
|
require.Contains(t, buf.String(), "Computation result retrieved and saved successfully")
|
|
buf.Reset()
|
|
}
|
|
|
|
files, err := filepath.Glob("results*.zip")
|
|
require.NoError(t, err)
|
|
|
|
t.Cleanup(func() {
|
|
for _, file := range files {
|
|
os.Remove(file)
|
|
}
|
|
os.Remove(privateKeyFile)
|
|
})
|
|
}
|
|
|
|
func TestResultsCmd_InvalidPrivateKey(t *testing.T) {
|
|
mockSDK := new(mocks.SDK)
|
|
mockSDK.On("Result", mock.Anything, mock.Anything, mock.Anything).Return(nil).Run(func(args mock.Arguments) {
|
|
_, err := args.Get(2).(*os.File).WriteString(compResult)
|
|
require.NoError(t, err)
|
|
})
|
|
testCLI := CLI{agentSDK: mockSDK}
|
|
|
|
invalidPrivateKey, err := os.CreateTemp("", "invalid_private_key.pem")
|
|
require.NoError(t, err)
|
|
err = invalidPrivateKey.Close()
|
|
require.NoError(t, err)
|
|
|
|
t.Cleanup(func() {
|
|
err := os.Remove(invalidPrivateKey.Name())
|
|
require.NoError(t, err)
|
|
})
|
|
|
|
cmd := testCLI.NewResultsCmd()
|
|
buf := new(bytes.Buffer)
|
|
cmd.SetOut(buf)
|
|
cmd.SetArgs([]string{invalidPrivateKey.Name()})
|
|
err = cmd.Execute()
|
|
require.NoError(t, err)
|
|
|
|
require.Contains(t, buf.String(), "Error decoding private key")
|
|
mockSDK.AssertNotCalled(t, "Result", mock.Anything, mock.Anything, mock.Anything)
|
|
}
|
|
|
|
func TestResultsCmd(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
setupMock func(*mocks.SDK)
|
|
setupFiles func() (string, error)
|
|
connectErr error
|
|
expectedOutput string
|
|
cleanup func()
|
|
}{
|
|
{
|
|
name: "successful result retrieval",
|
|
setupMock: func(m *mocks.SDK) {
|
|
m.On("Result", mock.Anything, mock.Anything, mock.Anything).Return(nil).Run(func(args mock.Arguments) {
|
|
_, err := args.Get(2).(*os.File).WriteString(compResult)
|
|
require.NoError(t, err)
|
|
})
|
|
},
|
|
setupFiles: func() (string, error) {
|
|
return privateKeyFile, generateRSAPrivateKeyFile(privateKeyFile)
|
|
},
|
|
expectedOutput: "Computation result retrieved and saved successfully",
|
|
cleanup: func() {
|
|
files, _ := filepath.Glob("results*.zip")
|
|
for _, file := range files {
|
|
os.Remove(file)
|
|
}
|
|
os.Remove(privateKeyFile)
|
|
},
|
|
},
|
|
{
|
|
name: "missing private key file",
|
|
setupMock: func(m *mocks.SDK) {
|
|
m.On("Result", mock.Anything, mock.Anything, mock.Anything).Return(nil).Run(func(args mock.Arguments) {
|
|
_, err := args.Get(2).(*os.File).WriteString(compResult)
|
|
require.NoError(t, err)
|
|
})
|
|
},
|
|
setupFiles: func() (string, error) {
|
|
return "non_existent_private_key.pem", nil
|
|
},
|
|
expectedOutput: "Error reading private key file",
|
|
},
|
|
{
|
|
name: "result retrieval failure",
|
|
setupMock: func(m *mocks.SDK) {
|
|
m.On("Result", mock.Anything, mock.Anything, mock.Anything).Return(errors.New("error retrieving computation result"))
|
|
},
|
|
setupFiles: func() (string, error) {
|
|
return privateKeyFile, generateRSAPrivateKeyFile(privateKeyFile)
|
|
},
|
|
expectedOutput: "error retrieving computation result",
|
|
cleanup: func() {
|
|
os.Remove(privateKeyFile)
|
|
},
|
|
},
|
|
{
|
|
name: "connection error",
|
|
setupMock: func(m *mocks.SDK) {
|
|
},
|
|
setupFiles: func() (string, error) { return "", nil },
|
|
connectErr: errors.New("failed to connect to agent"),
|
|
expectedOutput: "Failed to connect to agent",
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
mockSDK := new(mocks.SDK)
|
|
if tt.setupMock != nil {
|
|
tt.setupMock(mockSDK)
|
|
}
|
|
|
|
testCLI := CLI{
|
|
agentSDK: mockSDK,
|
|
connectErr: tt.connectErr,
|
|
}
|
|
|
|
file, err := tt.setupFiles()
|
|
require.NoError(t, err)
|
|
|
|
cmd := testCLI.NewResultsCmd()
|
|
buf := new(bytes.Buffer)
|
|
cmd.SetOut(buf)
|
|
cmd.SetArgs([]string{file})
|
|
err = cmd.Execute()
|
|
require.NoError(t, err)
|
|
|
|
require.Contains(t, buf.String(), tt.expectedOutput)
|
|
|
|
if tt.cleanup != nil {
|
|
tt.cleanup()
|
|
}
|
|
})
|
|
}
|
|
}
|