mirror of
https://github.com/status-im/status-go.git
synced 2025-01-26 06:30:23 +00:00
51c1193ed2
* feat_: Implement request logging functionality * chore_: lint fix * chore_: address review feedback * test_: check panic recovery panic * chore_: add json tags
48 lines
1.5 KiB
Go
48 lines
1.5 KiB
Go
package statusgo
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"path"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/status-im/status-go/logutils/requestlog"
|
|
"github.com/status-im/status-go/protocol/requests"
|
|
)
|
|
|
|
func TestInitLogging(t *testing.T) {
|
|
tempDir := t.TempDir()
|
|
t.Logf("temp dir: %s", tempDir)
|
|
gethLogFile := path.Join(tempDir, "geth.log")
|
|
requestsLogFile := path.Join(tempDir, "requests.log")
|
|
logSettings := fmt.Sprintf(`{"LogRequestGo": true, "LogRequestFile": "%s", "File": "%s", "Level": "INFO", "Enabled": true, "MobileSystem": false}`, requestsLogFile, gethLogFile)
|
|
response := InitLogging(logSettings)
|
|
require.Equal(t, `{"error":""}`, response)
|
|
_, err := os.Stat(gethLogFile)
|
|
require.NoError(t, err)
|
|
require.True(t, requestlog.IsRequestLoggingEnabled())
|
|
|
|
// requests log file should not be created yet
|
|
_, err = os.Stat(requestsLogFile)
|
|
require.Error(t, err)
|
|
require.True(t, os.IsNotExist(err))
|
|
|
|
createAccountRequest := &requests.CreateAccount{
|
|
DisplayName: "some-display-name",
|
|
CustomizationColor: "#ffffff",
|
|
Password: "some-password",
|
|
RootDataDir: tempDir,
|
|
LogFilePath: gethLogFile,
|
|
}
|
|
_, err = statusBackend.CreateAccountAndLogin(createAccountRequest)
|
|
require.NoError(t, err)
|
|
result := CallPrivateRPC(`{"jsonrpc":"2.0","method":"settings_getSettings","params":[],"id":1}`)
|
|
require.NotContains(t, result, "error")
|
|
// Check if request log file exists now
|
|
_, err = os.Stat(requestsLogFile)
|
|
require.NoError(t, err)
|
|
require.FileExists(t, requestsLogFile)
|
|
}
|