Compare commits

...

2 commits

Author SHA1 Message Date
Leon Mika b8ec434b5d Added tests and fixed other unit tests
All checks were successful
ci / build (pull_request) Successful in 3m48s
2025-10-24 17:26:38 +11:00
Leon Mika a1bda94e74 Fixed docker 2025-10-24 17:23:38 +11:00
2 changed files with 48 additions and 8 deletions

View file

@ -1,8 +1,9 @@
package cmdpacks_test package cmdpacks_test
import ( import (
"github.com/stretchr/testify/assert"
"testing" "testing"
"github.com/stretchr/testify/assert"
) )
func TestModPB_Copy(t *testing.T) { func TestModPB_Copy(t *testing.T) {
@ -10,8 +11,8 @@ func TestModPB_Copy(t *testing.T) {
svc := newService(t) svc := newService(t)
_, err := svc.CommandController.ExecuteAndWait(t.Context(), ` _, err := svc.CommandController.ExecuteAndWait(t.Context(), `
$items = @resultset.Items items = @resultset.Items
$skItems = $items | map { |i| $i.sk } | lists:uniq skItems = $items | map { |i| $i.sk } | lists:uniq
pb:copy ($skItems | strs:join "\n") pb:copy ($skItems | strs:join "\n")
`) `)
assert.NoError(t, err) assert.NoError(t, err)
@ -23,8 +24,8 @@ func TestModPB_Copy(t *testing.T) {
svc := newService(t) svc := newService(t)
_, err := svc.CommandController.ExecuteAndWait(t.Context(), ` _, err := svc.CommandController.ExecuteAndWait(t.Context(), `
$items = @resultset.Items items = @resultset.Items
$skItems = $items | map { |i| $i.alpha } | filter !nil | lists:uniq skItems = $items | map { |i| $i.alpha } | filter !nil | lists:uniq
pb:copy ($skItems | strs:join "\n") pb:copy ($skItems | strs:join "\n")
`) `)
assert.NoError(t, err) assert.NoError(t, err)

View file

@ -2,10 +2,11 @@ package cmdpacks_test
import ( import (
"fmt" "fmt"
"testing"
"github.com/stretchr/testify/assert"
"lmika.dev/cmd/dynamo-browse/internal/common/ui/commandctrl/cmdpacks" "lmika.dev/cmd/dynamo-browse/internal/common/ui/commandctrl/cmdpacks"
"lmika.dev/cmd/dynamo-browse/internal/dynamo-browse/models" "lmika.dev/cmd/dynamo-browse/internal/dynamo-browse/models"
"github.com/stretchr/testify/assert"
"testing"
) )
func TestModRS_New(t *testing.T) { func TestModRS_New(t *testing.T) {
@ -70,7 +71,7 @@ func TestModRS_Union(t *testing.T) {
svc := newService(t, withDefaultLimit(2)) svc := newService(t, withDefaultLimit(2))
rsProxy, err := svc.CommandController.ExecuteAndWait(t.Context(), ` rsProxy, err := svc.CommandController.ExecuteAndWait(t.Context(), `
$mr = rs:union @resultset (rs:next-page @resultset) mr = rs:union @resultset (rs:next-page @resultset)
assert (eq (len $mr.Items) 3) "expected len == 3" assert (eq (len $mr.Items) 3) "expected len == 3"
assert (eq $mr.Items.(0).pk "abc") "expected 0.pk" assert (eq $mr.Items.(0).pk "abc") "expected 0.pk"
@ -152,3 +153,41 @@ func TestModRS_Query(t *testing.T) {
}) })
} }
} }
func TestModRS_First(t *testing.T) {
tests := []struct {
descr string
cmd string
}{
{
descr: "returns the first item in sorted order",
cmd: `
rs = rs:query 'pk="abc"' -table service-test-data
assert (eq $rs.First.pk "abc") "expected First.pk == abc"
assert (eq $rs.First.sk "111") "expected First.sk == 111"
`,
}, {
descr: "returns the first item in single item",
cmd: `
rs = rs:query 'pk="abc" and sk="222"' -table service-test-data
assert (eq $rs.First.pk "abc") "expected First.pk == abc"
assert (eq $rs.First.sk "222") "expected First.sk == 222"
assert (eq $rs.First.beta 1231) "expected First.beta == 1231"
`,
}, {
descr: "returns the first item in empty result",
cmd: `
rs = rs:query 'pk="zzz"' -table service-test-data
assert (eq $rs.First ()) "expected First to be nil"
`,
},
}
for _, tt := range tests {
t.Run(tt.descr, func(t *testing.T) {
svc := newService(t)
_, err := svc.CommandController.ExecuteAndWait(t.Context(), tt.cmd)
assert.NoError(t, err)
})
}
}