Skip to content

Commit

Permalink
teatest: use one program within another
Browse files Browse the repository at this point in the history
Signed-off-by: Carlos Alexandro Becker <[email protected]>
  • Loading branch information
caarlos0 committed Feb 8, 2024
1 parent f149929 commit 41a8328
Show file tree
Hide file tree
Showing 3 changed files with 100 additions and 2 deletions.
87 changes: 87 additions & 0 deletions exp/teatest/send_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
package teatest_test

import (
"fmt"
"strings"
"testing"
"time"

tea "github.com/charmbracelet/bubbletea"
"github.com/charmbracelet/x/exp/teatest"
)

func TestAppSendToOtherProgram(t *testing.T) {
m1 := &connectedModel{
name: "m1",
}
m2 := &connectedModel{
name: "m2",
}

tm1 := teatest.NewTestModel(t, m1, teatest.WithInitialTermSize(70, 30))
t.Cleanup(func() {
if err := tm1.Quit(); err != nil {
t.Fatal(err)
}
})
tm2 := teatest.NewTestModel(t, m2, teatest.WithInitialTermSize(70, 30))
t.Cleanup(func() {
if err := tm2.Quit(); err != nil {
t.Fatal(err)
}
})
m1.programs = append(m1.programs, tm2)
m2.programs = append(m2.programs, tm1)

tm1.Type("pp")
tm2.Type("pppp")

tm1.Type("q")
tm2.Type("q")

out1 := readBts(t, tm1.FinalOutput(t, teatest.WithFinalTimeout(time.Second)))
out2 := readBts(t, tm2.FinalOutput(t, teatest.WithFinalTimeout(time.Second)))

if string(out1) != string(out2) {
t.Errorf("output of both models should be the same, got:\n%v\nand:\n%v\n", string(out1), string(out2))
}

teatest.RequireEqualOutput(t, out1)
}

type connectedModel struct {
name string
programs []interface{ Send(tea.Msg) }
msgs []string
}

type ping string

func (m *connectedModel) Init() tea.Cmd {
return nil
}

func (m *connectedModel) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
switch msg := msg.(type) {
case tea.KeyMsg:
switch msg.String() {
case "p":
send := ping("from " + m.name)
m.msgs = append(m.msgs, string(send))
for _, p := range m.programs {
p.Send(send)
}
fmt.Printf("sent ping %q to others\n", send)
case "q":
return m, tea.Quit
}
case ping:
fmt.Printf("rcvd ping %q on %s\n", msg, m.name)
m.msgs = append(m.msgs, string(msg))
}
return m, nil
}

func (m *connectedModel) View() string {
return "All pings:\n" + strings.Join(m.msgs, "\n")
}
8 changes: 6 additions & 2 deletions exp/teatest/teatest.go
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ func NewTestModel(tb testing.TB, m tea.Model, options ...TestOption) *TestModel
<-interruptions
signal.Stop(interruptions)
tb.Log("interrupted")
tm.program.Quit()
tm.program.Kill()
}()

var opts TestModelOptions
Expand All @@ -162,6 +162,10 @@ func NewTestModel(tb testing.TB, m tea.Model, options ...TestOption) *TestModel
return tm
}

// GetProgram returns the underlying program.
// This should be used only to test apps that talk to other apps.
// func (tm *TestModel) GetProgram() *tea.Program { return tm.program }

func (tm *TestModel) waitDone(tb testing.TB, opts []FinalOpt) {
tm.done.Do(func() {
fopts := FinalOpts{}
Expand Down Expand Up @@ -244,7 +248,7 @@ func (tm *TestModel) Quit() error {
// Type types the given text into the given program.
func (tm *TestModel) Type(s string) {
for _, c := range []byte(s) {
tm.program.Send(tea.KeyMsg{
tm.Send(tea.KeyMsg{
Runes: []rune{rune(c)},
Type: tea.KeyRunes,
})
Expand Down
7 changes: 7 additions & 0 deletions exp/teatest/testdata/TestAppSendToOtherProgram.golden
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
[?25lAll pings:
from m1
from m1
from m2
from m2
from m2
from m2[?25h[?1002l[?1003l[?1006l

0 comments on commit 41a8328

Please sign in to comment.