Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
3224201b
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
3224201b
编写于
11月 16, 2020
作者:
S
SteVen Batten
提交者:
GitHub
11月 16, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
expose current flights on exp service
上级
771f9f9a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
33 addition
and
9 deletion
+33
-9
src/vs/workbench/services/experiment/common/experimentService.ts
...workbench/services/experiment/common/experimentService.ts
+33
-9
未找到文件。
src/vs/workbench/services/experiment/common/experimentService.ts
浏览文件 @
3224201b
...
...
@@ -6,18 +6,19 @@
import
{
createDecorator
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
*
as
platform
from
'
vs/base/common/platform
'
;
import
type
{
IKeyValueStorage
,
IExperimentationTelemetry
,
IExperimentationFilterProvider
,
ExperimentationService
as
TASClient
}
from
'
tas-client-umd
'
;
import
{
MementoObject
,
Memento
}
from
'
vs/workbench/common/memento
'
;
import
{
IProductService
}
from
'
vs/platform/product/common/productService
'
;
import
{
ITelemetryService
}
from
'
vs/platform/telemetry/common/telemetry
'
;
import
{
IStorageService
,
StorageScope
,
StorageTarget
}
from
'
vs/platform/storage/common/storage
'
;
import
{
ITelemetryData
}
from
'
vs/base/common/actions
'
;
import
{
registerSingleton
}
from
'
vs/platform/instantiation/common/extensions
'
;
import
{
IConfigurationService
}
from
'
vs/platform/configuration/common/configuration
'
;
import
product
from
'
vs/platform/product/common/product
'
;
export
const
ITASExperimentService
=
createDecorator
<
ITASExperimentService
>
(
'
TASExperimentService
'
);
export
interface
ITASExperimentService
{
readonly
_serviceBrand
:
undefined
;
getTreatment
<
T
extends
string
|
number
|
boolean
>
(
name
:
string
):
Promise
<
T
|
undefined
>
;
getCurrentExperiments
():
Promise
<
string
[]
|
undefined
>
;
}
const
storageKey
=
'
VSCode.ABExp.FeatureData
'
;
...
...
@@ -37,11 +38,20 @@ class MementoKeyValueStorage implements IKeyValueStorage {
}
class
ExperimentServiceTelemetry
implements
IExperimentationTelemetry
{
private
_lastAssignmentContext
:
string
|
undefined
;
constructor
(
private
telemetryService
:
ITelemetryService
)
{
}
get
assignmentContext
():
string
[]
|
undefined
{
return
this
.
_lastAssignmentContext
?.
split
(
'
;
'
);
}
// __GDPR__COMMON__ "VSCode.ABExp.Features" : { "classification": "SystemMetaData", "purpose": "FeatureInsight" }
// __GDPR__COMMON__ "abexp.assignmentcontext" : { "classification": "SystemMetaData", "purpose": "FeatureInsight" }
setSharedProperty
(
name
:
string
,
value
:
string
):
void
{
if
(
name
===
product
.
tasConfig
?.
assignmentContextTelemetryPropertyName
)
{
this
.
_lastAssignmentContext
=
value
;
}
this
.
telemetryService
.
setExperimentProperty
(
name
,
value
);
}
...
...
@@ -165,6 +175,7 @@ enum TargetPopulation {
export
class
ExperimentService
implements
ITASExperimentService
{
_serviceBrand
:
undefined
;
private
tasClient
:
Promise
<
TASClient
>
|
undefined
;
private
telemetry
:
ExperimentServiceTelemetry
|
undefined
;
private
static
MEMENTO_ID
=
'
experiment.service.memento
'
;
private
get
experimentsEnabled
():
boolean
{
...
...
@@ -172,13 +183,12 @@ export class ExperimentService implements ITASExperimentService {
}
constructor
(
@
IProductService
private
productService
:
IProductService
,
@
ITelemetryService
private
telemetryService
:
ITelemetryService
,
@
IStorageService
private
storageService
:
IStorageService
,
@
IConfigurationService
private
configurationService
:
IConfigurationService
,
)
{
if
(
this
.
productService
.
tasConfig
&&
this
.
experimentsEnabled
&&
this
.
telemetryService
.
isOptedIn
)
{
if
(
product
.
tasConfig
&&
this
.
experimentsEnabled
&&
this
.
telemetryService
.
isOptedIn
)
{
this
.
tasClient
=
this
.
setupTASClient
();
}
}
...
...
@@ -195,13 +205,27 @@ export class ExperimentService implements ITASExperimentService {
return
(
await
this
.
tasClient
).
getTreatmentVariable
<
T
>
(
'
vscode
'
,
name
);
}
async
getCurrentExperiments
():
Promise
<
string
[]
|
undefined
>
{
if
(
!
this
.
tasClient
)
{
return
undefined
;
}
if
(
!
this
.
experimentsEnabled
)
{
return
undefined
;
}
await
this
.
tasClient
;
return
this
.
telemetry
?.
assignmentContext
;
}
private
async
setupTASClient
():
Promise
<
TASClient
>
{
const
telemetryInfo
=
await
this
.
telemetryService
.
getTelemetryInfo
();
const
targetPopulation
=
telemetryInfo
.
msftInternal
?
TargetPopulation
.
Internal
:
(
this
.
productService
.
quality
===
'
stable
'
?
TargetPopulation
.
Public
:
TargetPopulation
.
Insiders
);
const
targetPopulation
=
telemetryInfo
.
msftInternal
?
TargetPopulation
.
Internal
:
(
product
.
quality
===
'
stable
'
?
TargetPopulation
.
Public
:
TargetPopulation
.
Insiders
);
const
machineId
=
telemetryInfo
.
machineId
;
const
filterProvider
=
new
ExperimentServiceFilterProvider
(
this
.
productService
.
version
,
this
.
productService
.
nameLong
,
product
.
version
,
product
.
nameLong
,
machineId
,
targetPopulation
);
...
...
@@ -209,12 +233,12 @@ export class ExperimentService implements ITASExperimentService {
const
memento
=
new
Memento
(
ExperimentService
.
MEMENTO_ID
,
this
.
storageService
);
const
keyValueStorage
=
new
MementoKeyValueStorage
(
memento
.
getMemento
(
StorageScope
.
GLOBAL
,
StorageTarget
.
MACHINE
));
const
telemetry
=
new
ExperimentServiceTelemetry
(
this
.
telemetryService
);
this
.
telemetry
=
new
ExperimentServiceTelemetry
(
this
.
telemetryService
);
const
tasConfig
=
this
.
productService
.
tasConfig
!
;
const
tasConfig
=
product
.
tasConfig
!
;
const
tasClient
=
new
(
await
import
(
'
tas-client-umd
'
)).
ExperimentationService
({
filterProviders
:
[
filterProvider
],
telemetry
:
telemetry
,
telemetry
:
t
his
.
t
elemetry
,
storageKey
:
storageKey
,
keyValueStorage
:
keyValueStorage
,
featuresTelemetryPropertyName
:
tasConfig
.
featuresTelemetryPropertyName
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录