diff options
Diffstat (limited to 'testrig')
| -rw-r--r-- | testrig/router.go | 30 | 
1 files changed, 30 insertions, 0 deletions
| diff --git a/testrig/router.go b/testrig/router.go index 6842c0210..7f883cd6a 100644 --- a/testrig/router.go +++ b/testrig/router.go @@ -20,7 +20,14 @@ package testrig  import (  	"context" +	"fmt" +	"os" +	"path/filepath" +	"runtime" +	"github.com/gin-gonic/gin" +	"github.com/spf13/viper" +	"github.com/superseriousbusiness/gotosocial/internal/config"  	"github.com/superseriousbusiness/gotosocial/internal/db"  	"github.com/superseriousbusiness/gotosocial/internal/router"  ) @@ -33,3 +40,26 @@ func NewTestRouter(db db.DB) router.Router {  	}  	return r  } + +// ConfigureTemplatesWithGin will panic on any errors related to template loading during tests +func ConfigureTemplatesWithGin(engine *gin.Engine) { + +	router.LoadTemplateFunctions(engine) + +	// https://stackoverflow.com/questions/31873396/is-it-possible-to-get-the-current-root-of-package-structure-as-a-string-in-golan +	_, runtimeCallerLocation, _, _ := runtime.Caller(0) +	projectRoot, err := filepath.Abs(filepath.Join(filepath.Dir(runtimeCallerLocation), "../")) +	if err != nil { +		panic(err) +	} + +	templateBaseDir := viper.GetString(config.Keys.WebTemplateBaseDir) + +	_, err = os.Stat(filepath.Join(projectRoot, templateBaseDir, "index.tmpl")) +	if err != nil { +		panic(fmt.Errorf("%s doesn't seem to contain the templates; index.tmpl is missing: %s", filepath.Join(projectRoot, templateBaseDir), err)) +	} + +	tmPath := filepath.Join(projectRoot, fmt.Sprintf("%s*", templateBaseDir)) +	engine.LoadHTMLGlob(tmPath) +} | 
