From dae1849463532362ca98ded75900d56606002a93 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B8rn=20Erik=20Pedersen?= Date: Mon, 21 Feb 2022 19:12:04 +0100 Subject: [PATCH] commands: Fix server panic regression And now with a proper server test. Fixes #9518 Fixes #9530 Fixes #9539 --- commands/commandeer.go | 2 +- commands/commands_test.go | 6 ++--- commands/server_test.go | 49 ++++++++++++++++++++++++++++++--------- hugolib/hugo_sites.go | 3 +++ 4 files changed, 45 insertions(+), 15 deletions(-) diff --git a/commands/commandeer.go b/commands/commandeer.go index 304ef7a7c64..bf42501e0ce 100644 --- a/commands/commandeer.go +++ b/commands/commandeer.go @@ -422,7 +422,7 @@ func (c *commandeer) loadConfig() error { } c.hugoSites = h // TODO(bep) improve. - if c.buildLock == nil { + if c.buildLock == nil && h != nil { c.buildLock = h.LockBuild } close(c.created) diff --git a/commands/commands_test.go b/commands/commands_test.go index b4fb8962134..b89e317c25d 100644 --- a/commands/commands_test.go +++ b/commands/commands_test.go @@ -329,7 +329,7 @@ type testSiteConfig struct { contentDir string } -func createSimpleTestSite(t *testing.T, cfg testSiteConfig) (string, func(), error) { +func createSimpleTestSite(t testing.TB, cfg testSiteConfig) (string, func(), error) { d, clean, e := htesting.CreateTempDir(hugofs.Os, "hugo-cli") if e != nil { return "", nil, e @@ -392,12 +392,12 @@ Environment: {{ hugo.Environment }} return d, clean, nil } -func writeFile(t *testing.T, filename, content string) { +func writeFile(t testing.TB, filename, content string) { must(t, os.MkdirAll(filepath.Dir(filename), os.FileMode(0755))) must(t, ioutil.WriteFile(filename, []byte(content), os.FileMode(0755))) } -func must(t *testing.T, err error) { +func must(t testing.TB, err error) { if err != nil { t.Fatal(err) } diff --git a/commands/server_test.go b/commands/server_test.go index 05d21a5165b..562fd498c70 100644 --- a/commands/server_test.go +++ b/commands/server_test.go @@ -29,12 +29,33 @@ import ( ) func TestServer(t *testing.T) { - if isWindowsCI() { - // TODO(bep) not sure why server tests have started to fail on the Windows CI server. - t.Skip("Skip server test on appveyor") - } c := qt.New(t) - dir, clean, err := createSimpleTestSite(t, testSiteConfig{}) + + homeContent, err := runServerTestAndGetHome(c, "") + + c.Assert(err, qt.IsNil) + c.Assert(homeContent, qt.Contains, "List: Hugo Commands") + c.Assert(homeContent, qt.Contains, "Environment: development") +} + +// Issue 9518 +func TestServerPanicOnConfigError(t *testing.T) { + c := qt.New(t) + + config := ` +[markup] +[markup.highlight] +linenos='table' +` + + _, err := runServerTestAndGetHome(c, config) + + c.Assert(err, qt.IsNotNil) + c.Assert(err.Error(), qt.Contains, "cannot parse 'Highlight.LineNos' as bool:") +} + +func runServerTestAndGetHome(c *qt.C, config string) (string, error) { + dir, clean, err := createSimpleTestSite(c, testSiteConfig{configTOML: config}) defer clean() c.Assert(err, qt.IsNil) @@ -45,6 +66,7 @@ func TestServer(t *testing.T) { os.RemoveAll(dir) }() + errors := make(chan error) stop := make(chan bool) b := newCommandsBuilder() @@ -54,25 +76,30 @@ func TestServer(t *testing.T) { cmd.SetArgs([]string{"-s=" + dir, fmt.Sprintf("-p=%d", port)}) go func() { - _, err = cmd.ExecuteC() - c.Assert(err, qt.IsNil) + _, err := cmd.ExecuteC() + if err != nil { + errors <- err + } }() + select { // There is no way to know exactly when the server is ready for connections. // We could improve by something like https://golang.org/pkg/net/http/httptest/#Server // But for now, let us sleep and pray! - time.Sleep(2 * time.Second) + case <-time.After(2 * time.Second): + case err := <-errors: + return "", err + } resp, err := http.Get("http://localhost:1331/") c.Assert(err, qt.IsNil) defer resp.Body.Close() homeContent := helpers.ReaderToString(resp.Body) - c.Assert(homeContent, qt.Contains, "List: Hugo Commands") - c.Assert(homeContent, qt.Contains, "Environment: development") - // Stop the server. stop <- true + + return homeContent, nil } func TestFixURL(t *testing.T) { diff --git a/hugolib/hugo_sites.go b/hugolib/hugo_sites.go index f1930fd7155..d2f4426d58a 100644 --- a/hugolib/hugo_sites.go +++ b/hugolib/hugo_sites.go @@ -390,6 +390,9 @@ func newHugoSites(cfg deps.DepsCfg, sites ...*Site) (*HugoSites, error) { } h.Deps = sites[0].Deps + if h.Deps == nil { + return nil, initErr + } // Only needed in server mode. // TODO(bep) clean up the running vs watching terms