mirror of
https://github.com/status-im/status-go.git
synced 2025-01-11 23:25:29 +00:00
e0eb737c51
* fix(TestProfilingCPU)_: enable run with -count=2 * fix(TestProfilingMem)_: enable run with -count=2 * fix(zaputil)_: register encoder only once * fix(timesource)_: global variables override in tests * fix(TestClosingsqlDB)_: delete database from cache * fix(postgres/helpers)_: drop connections before dropping database * fix_: linter * chore_: remove redundant condition
41 lines
869 B
Go
41 lines
869 B
Go
package profiling
|
|
|
|
import (
|
|
"errors"
|
|
"os"
|
|
"path/filepath"
|
|
"runtime/pprof"
|
|
)
|
|
|
|
// CPUFilename is a filename in which the CPU profiling is stored.
|
|
const CPUFilename = "status_cpu.prof"
|
|
|
|
var cpuFile *os.File
|
|
|
|
// StartCPUProfile enables CPU profiling for the current process. While profiling,
|
|
// the profile will be buffered and written to the file in folder dataDir.
|
|
func StartCPUProfile(dataDir string) error {
|
|
if cpuFile != nil {
|
|
return errors.New("cpu profiling is already started")
|
|
}
|
|
|
|
var err error
|
|
cpuFile, err = os.Create(filepath.Join(dataDir, CPUFilename))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return pprof.StartCPUProfile(cpuFile)
|
|
}
|
|
|
|
// StopCPUProfile stops the current CPU profile, if any, and closes the file.
|
|
func StopCPUProfile() error {
|
|
if cpuFile == nil {
|
|
return nil
|
|
}
|
|
pprof.StopCPUProfile()
|
|
err := cpuFile.Close()
|
|
cpuFile = nil
|
|
return err
|
|
}
|