Tests for service project & a small panic guard
Tests helped flush out that we would panic if a project was attempting to be created without a basis. Sometimes tests help!
This commit is contained in:
parent
a86bf277aa
commit
e7533103e8
@ -8,7 +8,6 @@ import (
|
||||
"github.com/hashicorp/vagrant/internal/server/proto/vagrant_server"
|
||||
)
|
||||
|
||||
// TODO: test
|
||||
func (s *service) UpsertProject(
|
||||
ctx context.Context,
|
||||
req *vagrant_server.UpsertProjectRequest,
|
||||
@ -21,7 +20,6 @@ func (s *service) UpsertProject(
|
||||
return &vagrant_server.UpsertProjectResponse{Project: result}, nil
|
||||
}
|
||||
|
||||
// TODO: test
|
||||
func (s *service) GetProject(
|
||||
ctx context.Context,
|
||||
req *vagrant_server.GetProjectRequest,
|
||||
@ -45,7 +43,6 @@ func (s *service) FindProject(
|
||||
return &vagrant_server.FindProjectResponse{Project: result}, nil
|
||||
}
|
||||
|
||||
// TODO: test
|
||||
func (s *service) ListProjects(
|
||||
ctx context.Context,
|
||||
req *empty.Empty,
|
||||
|
||||
135
internal/server/singleprocess/service_project_test.go
Normal file
135
internal/server/singleprocess/service_project_test.go
Normal file
@ -0,0 +1,135 @@
|
||||
package singleprocess
|
||||
|
||||
import (
|
||||
"context"
|
||||
"testing"
|
||||
|
||||
"github.com/hashicorp/vagrant-plugin-sdk/proto/vagrant_plugin_sdk"
|
||||
"github.com/hashicorp/vagrant/internal/server"
|
||||
"github.com/hashicorp/vagrant/internal/server/proto/vagrant_server"
|
||||
"github.com/stretchr/testify/require"
|
||||
"google.golang.org/grpc/codes"
|
||||
"google.golang.org/grpc/status"
|
||||
"google.golang.org/protobuf/types/known/emptypb"
|
||||
)
|
||||
|
||||
func TestServiceProject(t *testing.T) {
|
||||
ctx := context.Background()
|
||||
|
||||
t.Run("set and get", func(t *testing.T) {
|
||||
require := require.New(t)
|
||||
db := testDB(t)
|
||||
impl, err := New(WithDB(db))
|
||||
require.NoError(err)
|
||||
client := server.TestServer(t, impl)
|
||||
|
||||
// need a basis to have a project
|
||||
basisResp, err := client.UpsertBasis(ctx, &vagrant_server.UpsertBasisRequest{
|
||||
Basis: &vagrant_server.Basis{
|
||||
Name: "mybasis",
|
||||
},
|
||||
})
|
||||
require.NoError(err)
|
||||
|
||||
resp, err := client.UpsertProject(ctx, &vagrant_server.UpsertProjectRequest{
|
||||
Project: &vagrant_server.Project{
|
||||
Name: "myproject",
|
||||
Basis: &vagrant_plugin_sdk.Ref_Basis{ResourceId: basisResp.Basis.ResourceId},
|
||||
},
|
||||
})
|
||||
require.NoError(err)
|
||||
require.NotNil(resp)
|
||||
require.NotEmpty(resp.Project.ResourceId)
|
||||
require.Equal("myproject", resp.Project.Name)
|
||||
|
||||
getResp, err := client.GetProject(ctx, &vagrant_server.GetProjectRequest{
|
||||
Project: &vagrant_plugin_sdk.Ref_Project{
|
||||
ResourceId: resp.Project.ResourceId,
|
||||
},
|
||||
})
|
||||
require.NoError(err)
|
||||
require.NotNil(getResp)
|
||||
require.Equal("myproject", getResp.Project.Name)
|
||||
})
|
||||
|
||||
t.Run("find and list", func(t *testing.T) {
|
||||
require := require.New(t)
|
||||
db := testDB(t)
|
||||
impl, err := New(WithDB(db))
|
||||
require.NoError(err)
|
||||
client := server.TestServer(t, impl)
|
||||
|
||||
// first insert
|
||||
basisResp, err := client.UpsertBasis(ctx, &vagrant_server.UpsertBasisRequest{
|
||||
Basis: &vagrant_server.Basis{
|
||||
Name: "mybasis",
|
||||
},
|
||||
})
|
||||
require.NoError(err)
|
||||
|
||||
resp, err := client.UpsertProject(ctx, &vagrant_server.UpsertProjectRequest{
|
||||
Project: &vagrant_server.Project{
|
||||
Name: "myproject",
|
||||
Basis: &vagrant_plugin_sdk.Ref_Basis{ResourceId: basisResp.Basis.ResourceId},
|
||||
},
|
||||
})
|
||||
require.NoError(err)
|
||||
require.NotNil(resp)
|
||||
require.NotEmpty(resp.Project.ResourceId)
|
||||
require.Equal("myproject", resp.Project.Name)
|
||||
|
||||
// see if we can find it by name
|
||||
findResp, err := client.FindProject(ctx, &vagrant_server.FindProjectRequest{
|
||||
Project: &vagrant_server.Project{Name: "myproject"},
|
||||
})
|
||||
require.NoError(err)
|
||||
require.NotNil(findResp)
|
||||
require.Equal(resp.Project.ResourceId, findResp.Project.ResourceId)
|
||||
require.Equal("myproject", findResp.Project.Name)
|
||||
|
||||
// then ensure it shows up in a list
|
||||
listResp, err := client.ListProjects(ctx, &emptypb.Empty{})
|
||||
require.NoError(err)
|
||||
require.NotNil(listResp)
|
||||
require.Len(listResp.Projects, 1)
|
||||
})
|
||||
|
||||
t.Run("reasonable errors: set without basis", func(t *testing.T) {
|
||||
require := require.New(t)
|
||||
db := testDB(t)
|
||||
impl, err := New(WithDB(db))
|
||||
require.NoError(err)
|
||||
client := server.TestServer(t, impl)
|
||||
|
||||
_, err = client.UpsertProject(ctx, &vagrant_server.UpsertProjectRequest{
|
||||
Project: &vagrant_server.Project{
|
||||
Name: "ihavenobasis",
|
||||
},
|
||||
})
|
||||
require.Error(err)
|
||||
require.Contains(err.Error(), "not found")
|
||||
})
|
||||
|
||||
t.Run("reasonable errors: get not found", func(t *testing.T) {
|
||||
require := require.New(t)
|
||||
db := testDB(t)
|
||||
impl, err := New(WithDB(db))
|
||||
require.NoError(err)
|
||||
client := server.TestServer(t, impl)
|
||||
|
||||
getResp, err := client.GetProject(ctx, &vagrant_server.GetProjectRequest{
|
||||
Project: &vagrant_plugin_sdk.Ref_Project{
|
||||
ResourceId: "idonotexist",
|
||||
},
|
||||
})
|
||||
require.Error(err)
|
||||
require.Nil(getResp)
|
||||
|
||||
// we expect this to be a GRPC error with a not found code and a decent
|
||||
// message
|
||||
st, ok := status.FromError(err)
|
||||
require.Equal(ok, true)
|
||||
require.Equal(st.Code(), codes.NotFound)
|
||||
require.Contains(st.Message(), "not found")
|
||||
})
|
||||
}
|
||||
@ -319,5 +319,8 @@ func (s *State) basisId(b *vagrant_server.Basis) []byte {
|
||||
}
|
||||
|
||||
func (s *State) basisIdByRef(ref *vagrant_plugin_sdk.Ref_Basis) []byte {
|
||||
if ref == nil {
|
||||
return []byte{}
|
||||
}
|
||||
return []byte(ref.ResourceId)
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user