Added some new test cases to catch more things and to see if the statistics on Code Climate change.
Added more TODO ideas for changes. Removed an unused field from LanguagePack.
This commit is contained in:
parent
d0e7b1c982
commit
8e81f922ea
@ -2,11 +2,6 @@ package counters
|
|||||||
|
|
||||||
import "sync"
|
import "sync"
|
||||||
|
|
||||||
type RWMutexCounterBucket struct {
|
|
||||||
counter int
|
|
||||||
sync.RWMutex
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: Make a neater API for this
|
// TODO: Make a neater API for this
|
||||||
var routeMapEnum map[string]int
|
var routeMapEnum map[string]int
|
||||||
var reverseRouteMapEnum map[int]string
|
var reverseRouteMapEnum map[int]string
|
||||||
@ -40,3 +35,8 @@ func SetOSMapEnum(osme map[string]int) {
|
|||||||
func SetReverseOSMapEnum(rosme map[int]string) {
|
func SetReverseOSMapEnum(rosme map[int]string) {
|
||||||
reverseOSMapEnum = rosme
|
reverseOSMapEnum = rosme
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type RWMutexCounterBucket struct {
|
||||||
|
counter int
|
||||||
|
sync.RWMutex
|
||||||
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Gosora Plugin System
|
* Gosora Plugin System
|
||||||
* Copyright Azareal 2016 - 2018
|
* Copyright Azareal 2016 - 2019
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
package common
|
package common
|
||||||
@ -410,6 +410,8 @@ func (plugin *Plugin) RemoveHook(name string, handler interface{}) {
|
|||||||
delete(plugin.Hooks, name)
|
delete(plugin.Hooks, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: Add a HasHook method to complete the AddHook, RemoveHook, etc. set?
|
||||||
|
|
||||||
var PluginsInited = false
|
var PluginsInited = false
|
||||||
|
|
||||||
func InitPlugins() {
|
func InitPlugins() {
|
||||||
|
@ -36,7 +36,7 @@ type LevelPhrases struct {
|
|||||||
// ! For the sake of thread safety, you must never modify a *LanguagePack directly, but to create a copy of it and overwrite the entry in the sync.Map
|
// ! For the sake of thread safety, you must never modify a *LanguagePack directly, but to create a copy of it and overwrite the entry in the sync.Map
|
||||||
type LanguagePack struct {
|
type LanguagePack struct {
|
||||||
Name string
|
Name string
|
||||||
Phrases map[string]string // Should we use a sync map or a struct for these? It would be nice, if we could keep all the phrases consistent.
|
// Should we use a sync map or a struct for these? It would be nice, if we could keep all the phrases consistent.
|
||||||
Levels LevelPhrases
|
Levels LevelPhrases
|
||||||
GlobalPerms map[string]string
|
GlobalPerms map[string]string
|
||||||
LocalPerms map[string]string
|
LocalPerms map[string]string
|
||||||
@ -140,11 +140,7 @@ func SaveLangPack(langPack *LanguagePack) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetPhrase(name string) (string, bool) {
|
// TODO: Merge these two maps?
|
||||||
res, ok := currentLangPack.Load().(*LanguagePack).Phrases[name]
|
|
||||||
return res, ok
|
|
||||||
}
|
|
||||||
|
|
||||||
func GetGlobalPermPhrase(name string) string {
|
func GetGlobalPermPhrase(name string) string {
|
||||||
res, ok := currentLangPack.Load().(*LanguagePack).GlobalPerms[name]
|
res, ok := currentLangPack.Load().(*LanguagePack).GlobalPerms[name]
|
||||||
if !ok {
|
if !ok {
|
||||||
@ -152,7 +148,6 @@ func GetGlobalPermPhrase(name string) string {
|
|||||||
}
|
}
|
||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetLocalPermPhrase(name string) string {
|
func GetLocalPermPhrase(name string) string {
|
||||||
res, ok := currentLangPack.Load().(*LanguagePack).LocalPerms[name]
|
res, ok := currentLangPack.Load().(*LanguagePack).LocalPerms[name]
|
||||||
if !ok {
|
if !ok {
|
||||||
|
21
misc_test.go
21
misc_test.go
@ -957,6 +957,27 @@ func TestPluginManager(t *testing.T) {
|
|||||||
expectNilErr(t, plugin2.SetActive(false))
|
expectNilErr(t, plugin2.SetActive(false))
|
||||||
plugin.Deactivate()
|
plugin.Deactivate()
|
||||||
expectNilErr(t, plugin.SetActive(false))
|
expectNilErr(t, plugin.SetActive(false))
|
||||||
|
|
||||||
|
// Hook tests
|
||||||
|
expect(t, common.RunSshook("haha", "ho") == "ho", "Sshook shouldn't have anything bound to it yet")
|
||||||
|
var handle = func(in string) (out string) {
|
||||||
|
return in + "hi"
|
||||||
|
}
|
||||||
|
plugin.AddHook("haha", handle)
|
||||||
|
expect(t, common.RunSshook("haha", "ho") == "hohi", "Sshook didn't give hohi")
|
||||||
|
plugin.RemoveHook("haha", handle)
|
||||||
|
expect(t, common.RunSshook("haha", "ho") == "ho", "Sshook shouldn't have anything bound to it anymore")
|
||||||
|
|
||||||
|
// TODO: Add tests for more hook types
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPhrases(t *testing.T) {
|
||||||
|
expect(t, common.GetGlobalPermPhrase("BanUsers") == "Can ban users", "Not the expected phrase")
|
||||||
|
expect(t, common.GetGlobalPermPhrase("NoSuchPerm") == "{lang.perms[NoSuchPerm]}", "Not the expected phrase")
|
||||||
|
expect(t, common.GetLocalPermPhrase("ViewTopic") == "Can view topics", "Not the expected phrase")
|
||||||
|
expect(t, common.GetLocalPermPhrase("NoSuchPerm") == "{lang.perms[NoSuchPerm]}", "Not the expected phrase")
|
||||||
|
|
||||||
|
// TODO: Cover the other phrase types, also try switching between languages to see if anything strange happens
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSlugs(t *testing.T) {
|
func TestSlugs(t *testing.T) {
|
||||||
|
@ -132,6 +132,7 @@ func AnalyticsViews(w http.ResponseWriter, r *http.Request, user common.User) co
|
|||||||
revLabelList, labelList, viewMap := analyticsTimeRangeToLabelList(timeRange)
|
revLabelList, labelList, viewMap := analyticsTimeRangeToLabelList(timeRange)
|
||||||
|
|
||||||
common.DebugLog("in panel.AnalyticsViews")
|
common.DebugLog("in panel.AnalyticsViews")
|
||||||
|
// TODO: Add some sort of analytics store / iterator?
|
||||||
acc := qgen.Builder.Accumulator()
|
acc := qgen.Builder.Accumulator()
|
||||||
rows, err := acc.Select("viewchunks").Columns("count, createdAt").Where("route = ''").DateCutoff("createdAt", timeRange.Quantity, timeRange.Unit).Query()
|
rows, err := acc.Select("viewchunks").Columns("count, createdAt").Where("route = ''").DateCutoff("createdAt", timeRange.Quantity, timeRange.Unit).Query()
|
||||||
if err != nil && err != sql.ErrNoRows {
|
if err != nil && err != sql.ErrNoRows {
|
||||||
|
Loading…
Reference in New Issue
Block a user