feat: Add creationTime function to process (#13542)

* Add process creation time

* Making docs clear for process creation time

* Address comments for process creation time

* Add process info cc file

* fixing comments around documentation

* Update doc for return val

* Capitalize number in docs

* chore: bump electron-typescript-definitions
This commit is contained in:
Husayn 2018-08-10 07:03:30 -07:00 committed by Charles Kerr
parent 9902d42760
commit 19cb5bad94
6 changed files with 34 additions and 7 deletions

View file

@ -14,6 +14,7 @@
#include "atom/common/native_mate_converters/string16_converter.h" #include "atom/common/native_mate_converters/string16_converter.h"
#include "atom/common/node_includes.h" #include "atom/common/node_includes.h"
#include "base/logging.h" #include "base/logging.h"
#include "base/process/process_info.h"
#include "base/process/process_metrics_iocounters.h" #include "base/process/process_metrics_iocounters.h"
#include "base/sys_info.h" #include "base/sys_info.h"
#include "native_mate/dictionary.h" #include "native_mate/dictionary.h"
@ -55,6 +56,7 @@ void AtomBindings::BindTo(v8::Isolate* isolate, v8::Local<v8::Object> process) {
dict.SetMethod("log", &Log); dict.SetMethod("log", &Log);
dict.SetMethod("getHeapStatistics", &GetHeapStatistics); dict.SetMethod("getHeapStatistics", &GetHeapStatistics);
dict.SetMethod("getProcessMemoryInfo", &GetProcessMemoryInfo); dict.SetMethod("getProcessMemoryInfo", &GetProcessMemoryInfo);
dict.SetMethod("getCreationTime", &GetCreationTime);
dict.SetMethod("getSystemMemoryInfo", &GetSystemMemoryInfo); dict.SetMethod("getSystemMemoryInfo", &GetSystemMemoryInfo);
dict.SetMethod("getCPUUsage", base::Bind(&AtomBindings::GetCPUUsage, dict.SetMethod("getCPUUsage", base::Bind(&AtomBindings::GetCPUUsage,
base::Unretained(this))); base::Unretained(this)));
@ -177,6 +179,16 @@ v8::Local<v8::Value> AtomBindings::GetProcessMemoryInfo(v8::Isolate* isolate) {
return dict.GetHandle(); return dict.GetHandle();
} }
// static
v8::Local<v8::Value> AtomBindings::GetCreationTime(v8::Isolate* isolate) {
auto timeValue = base::CurrentProcessInfo::CreationTime();
if (timeValue.is_null()) {
return v8::Null(isolate);
}
double jsTime = timeValue.ToJsTime();
return v8::Number::New(isolate, jsTime);
}
// static // static
v8::Local<v8::Value> AtomBindings::GetSystemMemoryInfo(v8::Isolate* isolate, v8::Local<v8::Value> AtomBindings::GetSystemMemoryInfo(v8::Isolate* isolate,
mate::Arguments* args) { mate::Arguments* args) {

View file

@ -37,6 +37,7 @@ class AtomBindings {
static void Hang(); static void Hang();
static v8::Local<v8::Value> GetHeapStatistics(v8::Isolate* isolate); static v8::Local<v8::Value> GetHeapStatistics(v8::Isolate* isolate);
static v8::Local<v8::Value> GetProcessMemoryInfo(v8::Isolate* isolate); static v8::Local<v8::Value> GetProcessMemoryInfo(v8::Isolate* isolate);
static v8::Local<v8::Value> GetCreationTime(v8::Isolate* isolate);
static v8::Local<v8::Value> GetSystemMemoryInfo(v8::Isolate* isolate, static v8::Local<v8::Value> GetSystemMemoryInfo(v8::Isolate* isolate,
mate::Arguments* args); mate::Arguments* args);
v8::Local<v8::Value> GetCPUUsage(v8::Isolate* isolate); v8::Local<v8::Value> GetCPUUsage(v8::Isolate* isolate);

View file

@ -111,6 +111,13 @@ The `process` object has the following methods:
Causes the main thread of the current process crash. Causes the main thread of the current process crash.
### `process.getCreationTime()`
Returns `Number | null` - The number of milliseconds since epoch, or `null` if the information is unavailable
Indicates the creation time of the application.
The time is represented as number of milliseconds since epoch. It returns null if it is unable to get the process creation time.
### `process.getCPUUsage()` ### `process.getCPUUsage()`
Returns [`CPUUsage`](structures/cpu-usage.md) Returns [`CPUUsage`](structures/cpu-usage.md)

12
package-lock.json generated
View file

@ -5,9 +5,9 @@
"requires": true, "requires": true,
"dependencies": { "dependencies": {
"@types/node": { "@types/node": {
"version": "7.0.66", "version": "7.0.69",
"resolved": "https://registry.npmjs.org/@types/node/-/node-7.0.66.tgz", "resolved": "https://registry.npmjs.org/@types/node/-/node-7.0.69.tgz",
"integrity": "sha512-W11u5kUNSX2+N6bJ7rPyLW4N98/xzrZg8apRoTwC0zbFjIie//oxgKAvqkQNQ97KVchB49ost74kgzoeDiE+Uw==", "integrity": "sha512-S5NC8HV6HnRipg8nC0j30TPl7ktXjRTKqgyINLNe8K/64UJUI8Lq0sRopXC0hProsV2F5ibj8IqPkl1xpGggrw==",
"dev": true "dev": true
}, },
"JSONStream": { "JSONStream": {
@ -2517,9 +2517,9 @@
} }
}, },
"electron-typescript-definitions": { "electron-typescript-definitions": {
"version": "1.3.5", "version": "1.3.6",
"resolved": "https://registry.npmjs.org/electron-typescript-definitions/-/electron-typescript-definitions-1.3.5.tgz", "resolved": "https://registry.npmjs.org/electron-typescript-definitions/-/electron-typescript-definitions-1.3.6.tgz",
"integrity": "sha512-7Ryb7AN0Re63oeX3wHytjX0ScVlDcgj+GSBi6Q8aSNpo4B/sffAgZK6P/b4idqF26hp2jPJWcjBMizUb0VNfAQ==", "integrity": "sha512-Wz6tPaaZ22lbfWwF9bzVSki7LMW96xilCT1M8eeNYZG6LcpA9x34jlrAZg5HZWTHXR2tfbTQhSmrY+FEVulD/A==",
"dev": true, "dev": true,
"requires": { "requires": {
"@types/node": "^7.0.18", "@types/node": "^7.0.18",

View file

@ -13,7 +13,7 @@
"dugite": "^1.45.0", "dugite": "^1.45.0",
"electabul": "~0.0.4", "electabul": "~0.0.4",
"electron-docs-linter": "^2.3.4", "electron-docs-linter": "^2.3.4",
"electron-typescript-definitions": "^1.3.5", "electron-typescript-definitions": "^1.3.6",
"github": "^9.2.0", "github": "^9.2.0",
"html-entities": "^1.2.1", "html-entities": "^1.2.1",
"husky": "^0.14.3", "husky": "^0.14.3",

View file

@ -1,6 +1,13 @@
const {expect} = require('chai') const {expect} = require('chai')
describe('process module', () => { describe('process module', () => {
describe('process.getCreationTime()', () => {
it('returns a creation time', () => {
const creationTime = process.getCreationTime()
expect(creationTime).to.be.a('number').and.be.at.least(0)
})
})
describe('process.getCPUUsage()', () => { describe('process.getCPUUsage()', () => {
it('returns a cpu usage object', () => { it('returns a cpu usage object', () => {
const cpuUsage = process.getCPUUsage() const cpuUsage = process.getCPUUsage()