more tests
This commit is contained in:
59
test/logger_test.go
Normal file
59
test/logger_test.go
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
package integration
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/marte-community/marte-dev-tools/internal/logger"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestLoggerPrint(t *testing.T) {
|
||||||
|
if os.Getenv("TEST_LOGGER_PRINT") == "1" {
|
||||||
|
logger.Printf("Test Printf %d", 123)
|
||||||
|
logger.Println("Test Println")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
cmd := exec.Command(os.Args[0], "-test.run=TestLoggerPrint")
|
||||||
|
cmd.Env = append(os.Environ(), "TEST_LOGGER_PRINT=1")
|
||||||
|
out, err := cmd.CombinedOutput()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("process failed: %v", err)
|
||||||
|
}
|
||||||
|
output := string(out)
|
||||||
|
if !strings.Contains(output, "Test Printf 123") {
|
||||||
|
t.Error("Printf output missing")
|
||||||
|
}
|
||||||
|
if !strings.Contains(output, "Test Println") {
|
||||||
|
t.Error("Println output missing")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLoggerFatal(t *testing.T) {
|
||||||
|
if os.Getenv("TEST_LOGGER_FATAL") == "1" {
|
||||||
|
logger.Fatal("Test Fatal")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
cmd := exec.Command(os.Args[0], "-test.run=TestLoggerFatal")
|
||||||
|
cmd.Env = append(os.Environ(), "TEST_LOGGER_FATAL=1")
|
||||||
|
err := cmd.Run()
|
||||||
|
if e, ok := err.(*exec.ExitError); ok && !e.Success() {
|
||||||
|
return // Success (exit code non-zero)
|
||||||
|
}
|
||||||
|
t.Fatalf("process ran with err %v, want exit status 1", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLoggerFatalf(t *testing.T) {
|
||||||
|
if os.Getenv("TEST_LOGGER_FATALF") == "1" {
|
||||||
|
logger.Fatalf("Test Fatalf %d", 456)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
cmd := exec.Command(os.Args[0], "-test.run=TestLoggerFatalf")
|
||||||
|
cmd.Env = append(os.Environ(), "TEST_LOGGER_FATALF=1")
|
||||||
|
err := cmd.Run()
|
||||||
|
if e, ok := err.(*exec.ExitError); ok && !e.Success() {
|
||||||
|
return // Success
|
||||||
|
}
|
||||||
|
t.Fatalf("process ran with err %v, want exit status 1", err)
|
||||||
|
}
|
||||||
110
test/lsp_coverage_test.go
Normal file
110
test/lsp_coverage_test.go
Normal file
@@ -0,0 +1,110 @@
|
|||||||
|
package integration
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"encoding/json"
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/marte-community/marte-dev-tools/internal/lsp"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestLSPIncrementalSync(t *testing.T) {
|
||||||
|
lsp.Documents = make(map[string]string)
|
||||||
|
var buf bytes.Buffer
|
||||||
|
lsp.Output = &buf
|
||||||
|
|
||||||
|
content := "Line1\nLine2\nLine3"
|
||||||
|
uri := "file://inc.marte"
|
||||||
|
lsp.Documents[uri] = content
|
||||||
|
|
||||||
|
// Replace "Line2" (Line 1, 0-5) with "Modified"
|
||||||
|
change := lsp.TextDocumentContentChangeEvent{
|
||||||
|
Range: &lsp.Range{
|
||||||
|
Start: lsp.Position{Line: 1, Character: 0},
|
||||||
|
End: lsp.Position{Line: 1, Character: 5},
|
||||||
|
},
|
||||||
|
Text: "Modified",
|
||||||
|
}
|
||||||
|
|
||||||
|
params := lsp.DidChangeTextDocumentParams{
|
||||||
|
TextDocument: lsp.VersionedTextDocumentIdentifier{URI: uri, Version: 2},
|
||||||
|
ContentChanges: []lsp.TextDocumentContentChangeEvent{change},
|
||||||
|
}
|
||||||
|
|
||||||
|
lsp.HandleDidChange(params)
|
||||||
|
|
||||||
|
expected := "Line1\nModified\nLine3"
|
||||||
|
if lsp.Documents[uri] != expected {
|
||||||
|
t.Errorf("Incremental update failed. Got:\n%q\nWant:\n%q", lsp.Documents[uri], expected)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Insert at end
|
||||||
|
change2 := lsp.TextDocumentContentChangeEvent{
|
||||||
|
Range: &lsp.Range{
|
||||||
|
Start: lsp.Position{Line: 2, Character: 5},
|
||||||
|
End: lsp.Position{Line: 2, Character: 5},
|
||||||
|
},
|
||||||
|
Text: "\nLine4",
|
||||||
|
}
|
||||||
|
params2 := lsp.DidChangeTextDocumentParams{
|
||||||
|
TextDocument: lsp.VersionedTextDocumentIdentifier{URI: uri, Version: 3},
|
||||||
|
ContentChanges: []lsp.TextDocumentContentChangeEvent{change2},
|
||||||
|
}
|
||||||
|
lsp.HandleDidChange(params2)
|
||||||
|
|
||||||
|
expected2 := "Line1\nModified\nLine3\nLine4"
|
||||||
|
if lsp.Documents[uri] != expected2 {
|
||||||
|
t.Errorf("Incremental insert failed. Got:\n%q\nWant:\n%q", lsp.Documents[uri], expected2)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLSPLifecycle(t *testing.T) {
|
||||||
|
var buf bytes.Buffer
|
||||||
|
lsp.Output = &buf
|
||||||
|
|
||||||
|
// Shutdown
|
||||||
|
msgShutdown := &lsp.JsonRpcMessage{
|
||||||
|
Method: "shutdown",
|
||||||
|
ID: 1,
|
||||||
|
}
|
||||||
|
lsp.HandleMessage(msgShutdown)
|
||||||
|
|
||||||
|
if !strings.Contains(buf.String(), `"result":null`) {
|
||||||
|
t.Error("Shutdown response incorrect")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Exit
|
||||||
|
if os.Getenv("TEST_LSP_EXIT") == "1" {
|
||||||
|
msgExit := &lsp.JsonRpcMessage{Method: "exit"}
|
||||||
|
lsp.HandleMessage(msgExit)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
cmd := exec.Command(os.Args[0], "-test.run=TestLSPLifecycle")
|
||||||
|
cmd.Env = append(os.Environ(), "TEST_LSP_EXIT=1")
|
||||||
|
err := cmd.Run()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Exit failed: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLSPMalformedParams(t *testing.T) {
|
||||||
|
var buf bytes.Buffer
|
||||||
|
lsp.Output = &buf
|
||||||
|
|
||||||
|
// Malformed Hover
|
||||||
|
msg := &lsp.JsonRpcMessage{
|
||||||
|
Method: "textDocument/hover",
|
||||||
|
ID: 2,
|
||||||
|
Params: json.RawMessage(`{invalid`),
|
||||||
|
}
|
||||||
|
lsp.HandleMessage(msg)
|
||||||
|
|
||||||
|
output := buf.String()
|
||||||
|
// Should respond with nil result
|
||||||
|
if !strings.Contains(output, `"result":null`) {
|
||||||
|
t.Errorf("Expected nil result for malformed params, got: %s", output)
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user