2022-08-07 22:09:39 +10:00
|
|
|
package gui
|
|
|
|
|
|
|
|
import (
|
2022-08-09 21:11:41 +10:00
|
|
|
"encoding/json"
|
2022-08-07 22:09:39 +10:00
|
|
|
"log"
|
2022-08-09 21:11:41 +10:00
|
|
|
"os"
|
|
|
|
"strconv"
|
2022-08-07 22:09:39 +10:00
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/jesseduffield/gocui"
|
2022-12-21 22:51:39 +11:00
|
|
|
"github.com/jesseduffield/lazygit/pkg/integration/components"
|
2022-08-09 21:27:12 +10:00
|
|
|
integrationTypes "github.com/jesseduffield/lazygit/pkg/integration/types"
|
2022-08-07 22:09:39 +10:00
|
|
|
"github.com/jesseduffield/lazygit/pkg/utils"
|
|
|
|
)
|
|
|
|
|
2022-08-09 20:27:44 +10:00
|
|
|
type IntegrationTest interface {
|
2022-08-13 12:56:04 +10:00
|
|
|
Run(guiAdapter *GuiDriver)
|
2022-08-09 20:27:44 +10:00
|
|
|
}
|
|
|
|
|
2022-08-09 21:27:12 +10:00
|
|
|
func (gui *Gui) handleTestMode(test integrationTypes.IntegrationTest) {
|
2022-12-21 22:51:39 +11:00
|
|
|
if os.Getenv(components.SANDBOX_ENV_VAR) == "true" {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-08-09 21:11:41 +10:00
|
|
|
if test != nil {
|
2022-08-07 22:09:39 +10:00
|
|
|
go func() {
|
|
|
|
time.Sleep(time.Millisecond * 100)
|
|
|
|
|
2022-08-13 12:56:04 +10:00
|
|
|
test.Run(&GuiDriver{gui: gui})
|
2022-08-07 22:09:39 +10:00
|
|
|
|
|
|
|
gui.g.Update(func(*gocui.Gui) error {
|
|
|
|
return gocui.ErrQuit
|
|
|
|
})
|
|
|
|
|
|
|
|
time.Sleep(time.Second * 1)
|
|
|
|
|
|
|
|
log.Fatal("gocui should have already exited")
|
|
|
|
}()
|
|
|
|
|
|
|
|
go utils.Safe(func() {
|
|
|
|
time.Sleep(time.Second * 40)
|
|
|
|
log.Fatal("40 seconds is up, lazygit recording took too long to complete")
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-08-09 21:11:41 +10:00
|
|
|
if Replaying() {
|
2022-08-07 22:09:39 +10:00
|
|
|
gui.g.RecordingConfig = gocui.RecordingConfig{
|
2022-08-09 21:11:41 +10:00
|
|
|
Speed: GetRecordingSpeed(),
|
2022-09-17 10:50:04 -07:00
|
|
|
Leeway: 1000,
|
2022-08-07 22:09:39 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
var err error
|
2022-08-09 21:11:41 +10:00
|
|
|
gui.g.Recording, err = LoadRecording()
|
2022-08-07 22:09:39 +10:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
go utils.Safe(func() {
|
|
|
|
time.Sleep(time.Second * 40)
|
|
|
|
log.Fatal("40 seconds is up, lazygit recording took too long to complete")
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2022-08-09 21:11:41 +10:00
|
|
|
|
|
|
|
func Headless() bool {
|
|
|
|
return os.Getenv("HEADLESS") != ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// OLD integration test format stuff
|
|
|
|
|
|
|
|
func Replaying() bool {
|
|
|
|
return os.Getenv("REPLAY_EVENTS_FROM") != ""
|
|
|
|
}
|
|
|
|
|
|
|
|
func RecordingEvents() bool {
|
|
|
|
return recordEventsTo() != ""
|
|
|
|
}
|
|
|
|
|
|
|
|
func recordEventsTo() string {
|
|
|
|
return os.Getenv("RECORD_EVENTS_TO")
|
|
|
|
}
|
|
|
|
|
|
|
|
func GetRecordingSpeed() float64 {
|
|
|
|
// humans are slow so this speeds things up.
|
|
|
|
speed := 1.0
|
|
|
|
envReplaySpeed := os.Getenv("SPEED")
|
|
|
|
if envReplaySpeed != "" {
|
|
|
|
var err error
|
|
|
|
speed, err = strconv.ParseFloat(envReplaySpeed, 64)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return speed
|
|
|
|
}
|
|
|
|
|
|
|
|
func LoadRecording() (*gocui.Recording, error) {
|
|
|
|
path := os.Getenv("REPLAY_EVENTS_FROM")
|
|
|
|
|
2022-09-13 18:11:03 +08:00
|
|
|
data, err := os.ReadFile(path)
|
2022-08-09 21:11:41 +10:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
recording := &gocui.Recording{}
|
|
|
|
|
|
|
|
err = json.Unmarshal(data, &recording)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return recording, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func SaveRecording(recording *gocui.Recording) error {
|
|
|
|
if !RecordingEvents() {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
jsonEvents, err := json.Marshal(recording)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
path := recordEventsTo()
|
|
|
|
|
2022-09-13 18:11:03 +08:00
|
|
|
return os.WriteFile(path, jsonEvents, 0o600)
|
2022-08-09 21:11:41 +10:00
|
|
|
}
|