roblox-opencode 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +112 -122
- package/commands/setup-game.md +108 -108
- package/commands/sync-check.md +53 -53
- package/core/roblox-core.md +93 -93
- package/dist/server.js +189 -167
- package/package.json +35 -35
- package/skills/roblox-analytics/SKILL.md +277 -277
- package/skills/roblox-analytics/references/event-batcher.luau +75 -75
- package/skills/roblox-animation-vfx/SKILL.md +1325 -1325
- package/skills/roblox-architecture/SKILL.md +863 -863
- package/skills/roblox-architecture/references/combat-systems.md +1381 -1381
- package/skills/roblox-code-review/SKILL.md +686 -686
- package/skills/roblox-data/SKILL.md +889 -889
- package/skills/roblox-data/references/inventory-systems.md +1729 -1729
- package/skills/roblox-debug/SKILL.md +98 -98
- package/skills/roblox-gui/SKILL.md +1103 -1103
- package/skills/roblox-gui-fusion/SKILL.md +150 -150
- package/skills/roblox-gui-fusion/references/inventory.luau +427 -427
- package/skills/roblox-gui-fusion/references/settings-menu.luau +579 -579
- package/skills/roblox-gui-fusion/references/shop.luau +411 -411
- package/skills/roblox-luau-mastery/SKILL.md +1519 -1519
- package/skills/roblox-monetization/SKILL.md +1084 -1084
- package/skills/roblox-monetization/references/process-receipt.luau +131 -131
- package/skills/roblox-networking/SKILL.md +669 -669
- package/skills/roblox-networking/references/remote-validator.luau +193 -193
- package/skills/roblox-publish-checklist/SKILL.md +127 -127
- package/skills/roblox-runtime/SKILL.md +753 -753
- package/skills/roblox-sharp-edges/SKILL.md +294 -294
- package/skills/roblox-sync/SKILL.md +126 -126
- package/skills/roblox-testing/SKILL.md +943 -943
- package/skills/roblox-tooling/SKILL.md +149 -149
- package/vendor/LICENSES/ProfileStore-LICENSE +201 -201
- package/vendor/LICENSES/RbxUtil-LICENSE +7 -7
- package/vendor/LICENSES/promise-LICENSE +20 -20
- package/vendor/LICENSES/t-LICENSE +21 -21
- package/vendor/LICENSES/testez-LICENSE +200 -200
- package/vendor/README.md +83 -83
- package/vendor/fusion/Animation/ExternalTime.luau +83 -83
- package/vendor/fusion/Animation/Spring.luau +321 -321
- package/vendor/fusion/Animation/Stopwatch.luau +127 -127
- package/vendor/fusion/Animation/Tween.luau +187 -187
- package/vendor/fusion/Animation/getTweenDuration.luau +27 -27
- package/vendor/fusion/Animation/getTweenRatio.luau +47 -47
- package/vendor/fusion/Animation/lerpType.luau +163 -163
- package/vendor/fusion/Animation/packType.luau +99 -99
- package/vendor/fusion/Animation/springCoefficients.luau +80 -80
- package/vendor/fusion/Animation/unpackType.luau +102 -102
- package/vendor/fusion/Colour/Oklab.luau +70 -70
- package/vendor/fusion/Colour/sRGB.luau +54 -54
- package/vendor/fusion/External.luau +167 -167
- package/vendor/fusion/ExternalDebug.luau +69 -69
- package/vendor/fusion/Graph/Observer.luau +113 -113
- package/vendor/fusion/Graph/castToGraph.luau +28 -28
- package/vendor/fusion/Graph/change.luau +80 -80
- package/vendor/fusion/Graph/depend.luau +32 -32
- package/vendor/fusion/Graph/evaluate.luau +55 -55
- package/vendor/fusion/Instances/Attribute.luau +57 -57
- package/vendor/fusion/Instances/AttributeChange.luau +46 -46
- package/vendor/fusion/Instances/AttributeOut.luau +63 -63
- package/vendor/fusion/Instances/Child.luau +21 -21
- package/vendor/fusion/Instances/Children.luau +147 -147
- package/vendor/fusion/Instances/Hydrate.luau +32 -32
- package/vendor/fusion/Instances/New.luau +52 -52
- package/vendor/fusion/Instances/OnChange.luau +49 -49
- package/vendor/fusion/Instances/OnEvent.luau +53 -53
- package/vendor/fusion/Instances/Out.luau +69 -69
- package/vendor/fusion/Instances/applyInstanceProps.luau +148 -148
- package/vendor/fusion/Instances/defaultProps.luau +194 -194
- package/vendor/fusion/LICENSE +21 -21
- package/vendor/fusion/Logging/formatError.luau +48 -48
- package/vendor/fusion/Logging/messages.luau +51 -51
- package/vendor/fusion/Logging/parseError.luau +24 -24
- package/vendor/fusion/Memory/checkLifetime.luau +133 -133
- package/vendor/fusion/Memory/deriveScope.luau +23 -23
- package/vendor/fusion/Memory/deriveScopeImpl.luau +44 -44
- package/vendor/fusion/Memory/doCleanup.luau +78 -78
- package/vendor/fusion/Memory/innerScope.luau +33 -33
- package/vendor/fusion/Memory/legacyCleanup.luau +17 -17
- package/vendor/fusion/Memory/needsDestruction.luau +16 -16
- package/vendor/fusion/Memory/poisonScope.luau +33 -33
- package/vendor/fusion/Memory/scopePool.luau +54 -54
- package/vendor/fusion/Memory/scoped.luau +26 -26
- package/vendor/fusion/Memory/whichLivesLonger.luau +74 -74
- package/vendor/fusion/RobloxExternal.luau +97 -97
- package/vendor/fusion/State/Computed.luau +138 -138
- package/vendor/fusion/State/For/Disassembly.luau +210 -210
- package/vendor/fusion/State/For/ForTypes.luau +30 -30
- package/vendor/fusion/State/For/init.luau +109 -109
- package/vendor/fusion/State/ForKeys.luau +93 -93
- package/vendor/fusion/State/ForPairs.luau +96 -96
- package/vendor/fusion/State/ForValues.luau +93 -93
- package/vendor/fusion/State/Value.luau +87 -87
- package/vendor/fusion/State/castToState.luau +25 -25
- package/vendor/fusion/State/peek.luau +30 -30
- package/vendor/fusion/Types.luau +314 -314
- package/vendor/fusion/Utility/Contextual.luau +90 -90
- package/vendor/fusion/Utility/Safe.luau +22 -22
- package/vendor/fusion/Utility/isSimilar.luau +29 -29
- package/vendor/fusion/Utility/merge.luau +35 -35
- package/vendor/fusion/Utility/nameOf.luau +34 -34
- package/vendor/fusion/Utility/never.luau +13 -13
- package/vendor/fusion/Utility/nicknames.luau +10 -10
- package/vendor/fusion/Utility/xtypeof.luau +26 -26
- package/vendor/fusion/init.luau +82 -82
- package/vendor/profilestore/init.luau +2242 -2242
- package/vendor/promise/init.luau +1982 -1982
- package/vendor/rbxutil/buffer-util/Buffer.test.luau +25 -25
- package/vendor/rbxutil/buffer-util/BufferReader.luau +228 -228
- package/vendor/rbxutil/buffer-util/BufferWriter.luau +269 -269
- package/vendor/rbxutil/buffer-util/DataTypeBuffer.luau +223 -223
- package/vendor/rbxutil/buffer-util/Types.luau +60 -60
- package/vendor/rbxutil/buffer-util/index.d.ts +153 -153
- package/vendor/rbxutil/buffer-util/init.luau +41 -41
- package/vendor/rbxutil/buffer-util/package.json +16 -16
- package/vendor/rbxutil/buffer-util/wally.toml +9 -9
- package/vendor/rbxutil/comm/Client/ClientComm.luau +232 -232
- package/vendor/rbxutil/comm/Client/ClientRemoteProperty.luau +156 -156
- package/vendor/rbxutil/comm/Client/ClientRemoteSignal.luau +109 -109
- package/vendor/rbxutil/comm/Client/init.luau +135 -135
- package/vendor/rbxutil/comm/Server/RemoteProperty.luau +295 -295
- package/vendor/rbxutil/comm/Server/RemoteSignal.luau +211 -211
- package/vendor/rbxutil/comm/Server/ServerComm.luau +211 -211
- package/vendor/rbxutil/comm/Server/init.luau +140 -140
- package/vendor/rbxutil/comm/Types.luau +18 -18
- package/vendor/rbxutil/comm/Util.luau +27 -27
- package/vendor/rbxutil/comm/init.luau +35 -35
- package/vendor/rbxutil/comm/wally.toml +13 -13
- package/vendor/rbxutil/component/init.luau +759 -759
- package/vendor/rbxutil/component/init.test.luau +311 -311
- package/vendor/rbxutil/component/wally.toml +14 -14
- package/vendor/rbxutil/concur/init.luau +542 -542
- package/vendor/rbxutil/concur/init.test.luau +364 -364
- package/vendor/rbxutil/concur/wally.toml +8 -8
- package/vendor/rbxutil/enum-list/init.luau +101 -101
- package/vendor/rbxutil/enum-list/init.test.luau +91 -91
- package/vendor/rbxutil/enum-list/wally.toml +8 -8
- package/vendor/rbxutil/find/index.d.ts +20 -20
- package/vendor/rbxutil/find/init.luau +44 -44
- package/vendor/rbxutil/find/package.json +17 -17
- package/vendor/rbxutil/find/wally.toml +8 -8
- package/vendor/rbxutil/input/Gamepad.luau +559 -559
- package/vendor/rbxutil/input/Keyboard.luau +124 -124
- package/vendor/rbxutil/input/Mouse.luau +278 -278
- package/vendor/rbxutil/input/PreferredInput.luau +91 -91
- package/vendor/rbxutil/input/Touch.luau +120 -120
- package/vendor/rbxutil/input/init.luau +33 -33
- package/vendor/rbxutil/input/wally.toml +12 -12
- package/vendor/rbxutil/loader/index.d.ts +15 -15
- package/vendor/rbxutil/loader/init.luau +137 -137
- package/vendor/rbxutil/loader/wally.toml +8 -8
- package/vendor/rbxutil/log/index.d.ts +38 -38
- package/vendor/rbxutil/log/init.luau +746 -746
- package/vendor/rbxutil/log/wally.toml +8 -8
- package/vendor/rbxutil/net/init.luau +190 -190
- package/vendor/rbxutil/net/wally.toml +8 -8
- package/vendor/rbxutil/option/index.d.ts +44 -44
- package/vendor/rbxutil/option/init.luau +489 -489
- package/vendor/rbxutil/option/init.test.luau +342 -342
- package/vendor/rbxutil/option/wally.toml +8 -8
- package/vendor/rbxutil/pid/index.d.ts +53 -53
- package/vendor/rbxutil/pid/init.luau +195 -195
- package/vendor/rbxutil/pid/package.json +16 -16
- package/vendor/rbxutil/pid/wally.toml +9 -9
- package/vendor/rbxutil/quaternion/index.d.ts +117 -117
- package/vendor/rbxutil/quaternion/init.luau +570 -570
- package/vendor/rbxutil/quaternion/package.json +16 -16
- package/vendor/rbxutil/quaternion/wally.toml +9 -9
- package/vendor/rbxutil/query/index.d.ts +43 -43
- package/vendor/rbxutil/query/init.luau +117 -117
- package/vendor/rbxutil/query/package.json +18 -18
- package/vendor/rbxutil/query/wally.toml +9 -9
- package/vendor/rbxutil/sequent/index.d.ts +28 -28
- package/vendor/rbxutil/sequent/init.luau +340 -340
- package/vendor/rbxutil/sequent/package.json +16 -16
- package/vendor/rbxutil/sequent/wally.toml +9 -9
- package/vendor/rbxutil/ser/init.luau +175 -175
- package/vendor/rbxutil/ser/init.test.luau +50 -50
- package/vendor/rbxutil/ser/wally.toml +11 -11
- package/vendor/rbxutil/shake/index.d.ts +36 -36
- package/vendor/rbxutil/shake/init.luau +532 -532
- package/vendor/rbxutil/shake/init.test.luau +267 -267
- package/vendor/rbxutil/shake/package.json +16 -16
- package/vendor/rbxutil/shake/wally.toml +9 -9
- package/vendor/rbxutil/signal/index.d.ts +100 -100
- package/vendor/rbxutil/signal/init.luau +432 -432
- package/vendor/rbxutil/signal/init.test.luau +190 -190
- package/vendor/rbxutil/signal/package.json +17 -17
- package/vendor/rbxutil/signal/wally.toml +9 -9
- package/vendor/rbxutil/silo/TableWatcher.luau +65 -65
- package/vendor/rbxutil/silo/Util.luau +55 -55
- package/vendor/rbxutil/silo/init.luau +338 -338
- package/vendor/rbxutil/silo/init.test.luau +215 -215
- package/vendor/rbxutil/silo/wally.toml +8 -8
- package/vendor/rbxutil/spring/index.d.ts +40 -40
- package/vendor/rbxutil/spring/init.luau +97 -97
- package/vendor/rbxutil/spring/package.json +17 -17
- package/vendor/rbxutil/spring/wally.toml +8 -8
- package/vendor/rbxutil/stream/index.d.ts +88 -88
- package/vendor/rbxutil/stream/init.luau +597 -597
- package/vendor/rbxutil/stream/package.json +18 -18
- package/vendor/rbxutil/stream/wally.toml +9 -9
- package/vendor/rbxutil/streamable/Streamable.luau +202 -202
- package/vendor/rbxutil/streamable/StreamableUtil.luau +80 -80
- package/vendor/rbxutil/streamable/init.luau +8 -8
- package/vendor/rbxutil/streamable/wally.toml +12 -12
- package/vendor/rbxutil/symbol/init.luau +56 -56
- package/vendor/rbxutil/symbol/init.test.luau +37 -37
- package/vendor/rbxutil/symbol/wally.toml +8 -8
- package/vendor/rbxutil/table-util/init.luau +938 -938
- package/vendor/rbxutil/table-util/init.test.luau +439 -439
- package/vendor/rbxutil/task-queue/index.d.ts +27 -27
- package/vendor/rbxutil/task-queue/init.luau +97 -97
- package/vendor/rbxutil/task-queue/wally.toml +8 -8
- package/vendor/rbxutil/timer/index.d.ts +81 -81
- package/vendor/rbxutil/timer/init.luau +249 -249
- package/vendor/rbxutil/timer/init.test.luau +73 -73
- package/vendor/rbxutil/timer/wally.toml +11 -11
- package/vendor/rbxutil/tree/index.d.ts +15 -15
- package/vendor/rbxutil/tree/init.luau +137 -137
- package/vendor/rbxutil/tree/wally.toml +8 -8
- package/vendor/rbxutil/trove/index.d.ts +46 -46
- package/vendor/rbxutil/trove/init.luau +787 -787
- package/vendor/rbxutil/trove/init.test.luau +203 -203
- package/vendor/rbxutil/trove/wally.toml +8 -8
- package/vendor/rbxutil/typed-remote/init.luau +196 -196
- package/vendor/rbxutil/typed-remote/wally.toml +8 -8
- package/vendor/rbxutil/wait-for/index.d.ts +17 -17
- package/vendor/rbxutil/wait-for/init.luau +257 -257
- package/vendor/rbxutil/wait-for/init.test.luau +182 -182
- package/vendor/rbxutil/wait-for/wally.toml +11 -11
- package/vendor/t/t.lua +1350 -1350
- package/vendor/testez/Context.lua +26 -26
- package/vendor/testez/Expectation.lua +311 -311
- package/vendor/testez/ExpectationContext.lua +38 -38
- package/vendor/testez/LifecycleHooks.lua +89 -89
- package/vendor/testez/Reporters/TeamCityReporter.lua +101 -101
- package/vendor/testez/Reporters/TextReporter.lua +105 -105
- package/vendor/testez/Reporters/TextReporterQuiet.lua +96 -96
- package/vendor/testez/TestBootstrap.lua +146 -146
- package/vendor/testez/TestEnum.lua +27 -27
- package/vendor/testez/TestPlan.lua +304 -304
- package/vendor/testez/TestPlanner.lua +39 -39
- package/vendor/testez/TestResults.lua +111 -111
- package/vendor/testez/TestRunner.lua +188 -188
- package/vendor/testez/TestSession.lua +243 -243
- package/vendor/testez/init.lua +39 -39
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
local Expectation = require(script.Parent.Expectation)
|
|
2
|
-
local checkMatcherNameCollisions = Expectation.checkMatcherNameCollisions
|
|
3
|
-
|
|
4
|
-
local function copy(t)
|
|
5
|
-
local result = {}
|
|
6
|
-
|
|
7
|
-
for key, value in pairs(t) do
|
|
8
|
-
result[key] = value
|
|
9
|
-
end
|
|
10
|
-
|
|
11
|
-
return result
|
|
12
|
-
end
|
|
13
|
-
|
|
14
|
-
local ExpectationContext = {}
|
|
15
|
-
ExpectationContext.__index = ExpectationContext
|
|
16
|
-
|
|
17
|
-
function ExpectationContext.new(parent)
|
|
18
|
-
local self = {
|
|
19
|
-
_extensions = parent and copy(parent._extensions) or {},
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
return setmetatable(self, ExpectationContext)
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
function ExpectationContext:startExpectationChain(...)
|
|
26
|
-
return Expectation.new(...):extend(self._extensions)
|
|
27
|
-
end
|
|
28
|
-
|
|
29
|
-
function ExpectationContext:extend(config)
|
|
30
|
-
for key, value in pairs(config) do
|
|
31
|
-
assert(self._extensions[key] == nil, string.format("Cannot reassign %q in expect.extend", key))
|
|
32
|
-
assert(checkMatcherNameCollisions(key), string.format("Cannot overwrite matcher %q; it already exists", key))
|
|
33
|
-
|
|
34
|
-
self._extensions[key] = value
|
|
35
|
-
end
|
|
36
|
-
end
|
|
37
|
-
|
|
38
|
-
return ExpectationContext
|
|
1
|
+
local Expectation = require(script.Parent.Expectation)
|
|
2
|
+
local checkMatcherNameCollisions = Expectation.checkMatcherNameCollisions
|
|
3
|
+
|
|
4
|
+
local function copy(t)
|
|
5
|
+
local result = {}
|
|
6
|
+
|
|
7
|
+
for key, value in pairs(t) do
|
|
8
|
+
result[key] = value
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
return result
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
local ExpectationContext = {}
|
|
15
|
+
ExpectationContext.__index = ExpectationContext
|
|
16
|
+
|
|
17
|
+
function ExpectationContext.new(parent)
|
|
18
|
+
local self = {
|
|
19
|
+
_extensions = parent and copy(parent._extensions) or {},
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
return setmetatable(self, ExpectationContext)
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
function ExpectationContext:startExpectationChain(...)
|
|
26
|
+
return Expectation.new(...):extend(self._extensions)
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
function ExpectationContext:extend(config)
|
|
30
|
+
for key, value in pairs(config) do
|
|
31
|
+
assert(self._extensions[key] == nil, string.format("Cannot reassign %q in expect.extend", key))
|
|
32
|
+
assert(checkMatcherNameCollisions(key), string.format("Cannot overwrite matcher %q; it already exists", key))
|
|
33
|
+
|
|
34
|
+
self._extensions[key] = value
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
return ExpectationContext
|
|
@@ -1,89 +1,89 @@
|
|
|
1
|
-
local TestEnum = require(script.Parent.TestEnum)
|
|
2
|
-
|
|
3
|
-
local LifecycleHooks = {}
|
|
4
|
-
LifecycleHooks.__index = LifecycleHooks
|
|
5
|
-
|
|
6
|
-
function LifecycleHooks.new()
|
|
7
|
-
local self = {
|
|
8
|
-
_stack = {},
|
|
9
|
-
}
|
|
10
|
-
return setmetatable(self, LifecycleHooks)
|
|
11
|
-
end
|
|
12
|
-
|
|
13
|
-
--[[
|
|
14
|
-
Returns an array of `beforeEach` hooks in FIFO order
|
|
15
|
-
]]
|
|
16
|
-
function LifecycleHooks:getBeforeEachHooks()
|
|
17
|
-
local key = TestEnum.NodeType.BeforeEach
|
|
18
|
-
local hooks = {}
|
|
19
|
-
|
|
20
|
-
for _, level in ipairs(self._stack) do
|
|
21
|
-
for _, hook in ipairs(level[key]) do
|
|
22
|
-
table.insert(hooks, hook)
|
|
23
|
-
end
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
return hooks
|
|
27
|
-
end
|
|
28
|
-
|
|
29
|
-
--[[
|
|
30
|
-
Returns an array of `afterEach` hooks in FILO order
|
|
31
|
-
]]
|
|
32
|
-
function LifecycleHooks:getAfterEachHooks()
|
|
33
|
-
local key = TestEnum.NodeType.AfterEach
|
|
34
|
-
local hooks = {}
|
|
35
|
-
|
|
36
|
-
for _, level in ipairs(self._stack) do
|
|
37
|
-
for _, hook in ipairs(level[key]) do
|
|
38
|
-
table.insert(hooks, 1, hook)
|
|
39
|
-
end
|
|
40
|
-
end
|
|
41
|
-
|
|
42
|
-
return hooks
|
|
43
|
-
end
|
|
44
|
-
|
|
45
|
-
--[[
|
|
46
|
-
Pushes uncalled beforeAll and afterAll hooks back up the stack
|
|
47
|
-
]]
|
|
48
|
-
function LifecycleHooks:popHooks()
|
|
49
|
-
table.remove(self._stack, #self._stack)
|
|
50
|
-
end
|
|
51
|
-
|
|
52
|
-
function LifecycleHooks:pushHooksFrom(planNode)
|
|
53
|
-
assert(planNode ~= nil)
|
|
54
|
-
|
|
55
|
-
table.insert(self._stack, {
|
|
56
|
-
[TestEnum.NodeType.BeforeAll] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.BeforeAll),
|
|
57
|
-
[TestEnum.NodeType.AfterAll] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.AfterAll),
|
|
58
|
-
[TestEnum.NodeType.BeforeEach] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.BeforeEach),
|
|
59
|
-
[TestEnum.NodeType.AfterEach] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.AfterEach),
|
|
60
|
-
})
|
|
61
|
-
end
|
|
62
|
-
|
|
63
|
-
--[[
|
|
64
|
-
Get the beforeAll hooks from the current level.
|
|
65
|
-
]]
|
|
66
|
-
function LifecycleHooks:getBeforeAllHooks()
|
|
67
|
-
return self._stack[#self._stack][TestEnum.NodeType.BeforeAll]
|
|
68
|
-
end
|
|
69
|
-
|
|
70
|
-
--[[
|
|
71
|
-
Get the afterAll hooks from the current level.
|
|
72
|
-
]]
|
|
73
|
-
function LifecycleHooks:getAfterAllHooks()
|
|
74
|
-
return self._stack[#self._stack][TestEnum.NodeType.AfterAll]
|
|
75
|
-
end
|
|
76
|
-
|
|
77
|
-
function LifecycleHooks:_getHooksOfType(nodes, key)
|
|
78
|
-
local hooks = {}
|
|
79
|
-
|
|
80
|
-
for _, node in ipairs(nodes) do
|
|
81
|
-
if node.type == key then
|
|
82
|
-
table.insert(hooks, node.callback)
|
|
83
|
-
end
|
|
84
|
-
end
|
|
85
|
-
|
|
86
|
-
return hooks
|
|
87
|
-
end
|
|
88
|
-
|
|
89
|
-
return LifecycleHooks
|
|
1
|
+
local TestEnum = require(script.Parent.TestEnum)
|
|
2
|
+
|
|
3
|
+
local LifecycleHooks = {}
|
|
4
|
+
LifecycleHooks.__index = LifecycleHooks
|
|
5
|
+
|
|
6
|
+
function LifecycleHooks.new()
|
|
7
|
+
local self = {
|
|
8
|
+
_stack = {},
|
|
9
|
+
}
|
|
10
|
+
return setmetatable(self, LifecycleHooks)
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
--[[
|
|
14
|
+
Returns an array of `beforeEach` hooks in FIFO order
|
|
15
|
+
]]
|
|
16
|
+
function LifecycleHooks:getBeforeEachHooks()
|
|
17
|
+
local key = TestEnum.NodeType.BeforeEach
|
|
18
|
+
local hooks = {}
|
|
19
|
+
|
|
20
|
+
for _, level in ipairs(self._stack) do
|
|
21
|
+
for _, hook in ipairs(level[key]) do
|
|
22
|
+
table.insert(hooks, hook)
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
return hooks
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
--[[
|
|
30
|
+
Returns an array of `afterEach` hooks in FILO order
|
|
31
|
+
]]
|
|
32
|
+
function LifecycleHooks:getAfterEachHooks()
|
|
33
|
+
local key = TestEnum.NodeType.AfterEach
|
|
34
|
+
local hooks = {}
|
|
35
|
+
|
|
36
|
+
for _, level in ipairs(self._stack) do
|
|
37
|
+
for _, hook in ipairs(level[key]) do
|
|
38
|
+
table.insert(hooks, 1, hook)
|
|
39
|
+
end
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
return hooks
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
--[[
|
|
46
|
+
Pushes uncalled beforeAll and afterAll hooks back up the stack
|
|
47
|
+
]]
|
|
48
|
+
function LifecycleHooks:popHooks()
|
|
49
|
+
table.remove(self._stack, #self._stack)
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
function LifecycleHooks:pushHooksFrom(planNode)
|
|
53
|
+
assert(planNode ~= nil)
|
|
54
|
+
|
|
55
|
+
table.insert(self._stack, {
|
|
56
|
+
[TestEnum.NodeType.BeforeAll] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.BeforeAll),
|
|
57
|
+
[TestEnum.NodeType.AfterAll] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.AfterAll),
|
|
58
|
+
[TestEnum.NodeType.BeforeEach] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.BeforeEach),
|
|
59
|
+
[TestEnum.NodeType.AfterEach] = self:_getHooksOfType(planNode.children, TestEnum.NodeType.AfterEach),
|
|
60
|
+
})
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
--[[
|
|
64
|
+
Get the beforeAll hooks from the current level.
|
|
65
|
+
]]
|
|
66
|
+
function LifecycleHooks:getBeforeAllHooks()
|
|
67
|
+
return self._stack[#self._stack][TestEnum.NodeType.BeforeAll]
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
--[[
|
|
71
|
+
Get the afterAll hooks from the current level.
|
|
72
|
+
]]
|
|
73
|
+
function LifecycleHooks:getAfterAllHooks()
|
|
74
|
+
return self._stack[#self._stack][TestEnum.NodeType.AfterAll]
|
|
75
|
+
end
|
|
76
|
+
|
|
77
|
+
function LifecycleHooks:_getHooksOfType(nodes, key)
|
|
78
|
+
local hooks = {}
|
|
79
|
+
|
|
80
|
+
for _, node in ipairs(nodes) do
|
|
81
|
+
if node.type == key then
|
|
82
|
+
table.insert(hooks, node.callback)
|
|
83
|
+
end
|
|
84
|
+
end
|
|
85
|
+
|
|
86
|
+
return hooks
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
return LifecycleHooks
|
|
@@ -1,102 +1,102 @@
|
|
|
1
|
-
local TestService = game:GetService("TestService")
|
|
2
|
-
|
|
3
|
-
local TestEnum = require(script.Parent.Parent.TestEnum)
|
|
4
|
-
|
|
5
|
-
local TeamCityReporter = {}
|
|
6
|
-
|
|
7
|
-
local function teamCityEscape(str)
|
|
8
|
-
str = string.gsub(str, "([]|'[])","|%1")
|
|
9
|
-
str = string.gsub(str, "\r", "|r")
|
|
10
|
-
str = string.gsub(str, "\n", "|n")
|
|
11
|
-
return str
|
|
12
|
-
end
|
|
13
|
-
|
|
14
|
-
local function teamCityEnterSuite(suiteName)
|
|
15
|
-
return string.format("##teamcity[testSuiteStarted name='%s']", teamCityEscape(suiteName))
|
|
16
|
-
end
|
|
17
|
-
|
|
18
|
-
local function teamCityLeaveSuite(suiteName)
|
|
19
|
-
return string.format("##teamcity[testSuiteFinished name='%s']", teamCityEscape(suiteName))
|
|
20
|
-
end
|
|
21
|
-
|
|
22
|
-
local function teamCityEnterCase(caseName)
|
|
23
|
-
return string.format("##teamcity[testStarted name='%s']", teamCityEscape(caseName))
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
local function teamCityLeaveCase(caseName)
|
|
27
|
-
return string.format("##teamcity[testFinished name='%s']", teamCityEscape(caseName))
|
|
28
|
-
end
|
|
29
|
-
|
|
30
|
-
local function teamCityFailCase(caseName, errorMessage)
|
|
31
|
-
return string.format("##teamcity[testFailed name='%s' message='%s']",
|
|
32
|
-
teamCityEscape(caseName), teamCityEscape(errorMessage))
|
|
33
|
-
end
|
|
34
|
-
|
|
35
|
-
local function reportNode(node, buffer, level)
|
|
36
|
-
buffer = buffer or {}
|
|
37
|
-
level = level or 0
|
|
38
|
-
if node.status == TestEnum.TestStatus.Skipped then
|
|
39
|
-
return buffer
|
|
40
|
-
end
|
|
41
|
-
if node.planNode.type == TestEnum.NodeType.Describe then
|
|
42
|
-
table.insert(buffer, teamCityEnterSuite(node.planNode.phrase))
|
|
43
|
-
for _, child in ipairs(node.children) do
|
|
44
|
-
reportNode(child, buffer, level + 1)
|
|
45
|
-
end
|
|
46
|
-
table.insert(buffer, teamCityLeaveSuite(node.planNode.phrase))
|
|
47
|
-
else
|
|
48
|
-
table.insert(buffer, teamCityEnterCase(node.planNode.phrase))
|
|
49
|
-
if node.status == TestEnum.TestStatus.Failure then
|
|
50
|
-
table.insert(buffer, teamCityFailCase(node.planNode.phrase, table.concat(node.errors,"\n")))
|
|
51
|
-
end
|
|
52
|
-
table.insert(buffer, teamCityLeaveCase(node.planNode.phrase))
|
|
53
|
-
end
|
|
54
|
-
end
|
|
55
|
-
|
|
56
|
-
local function reportRoot(node)
|
|
57
|
-
local buffer = {}
|
|
58
|
-
|
|
59
|
-
for _, child in ipairs(node.children) do
|
|
60
|
-
reportNode(child, buffer, 0)
|
|
61
|
-
end
|
|
62
|
-
|
|
63
|
-
return buffer
|
|
64
|
-
end
|
|
65
|
-
|
|
66
|
-
local function report(root)
|
|
67
|
-
local buffer = reportRoot(root)
|
|
68
|
-
|
|
69
|
-
return table.concat(buffer, "\n")
|
|
70
|
-
end
|
|
71
|
-
|
|
72
|
-
function TeamCityReporter.report(results)
|
|
73
|
-
local resultBuffer = {
|
|
74
|
-
"Test results:",
|
|
75
|
-
report(results),
|
|
76
|
-
("%d passed, %d failed, %d skipped"):format(
|
|
77
|
-
results.successCount,
|
|
78
|
-
results.failureCount,
|
|
79
|
-
results.skippedCount
|
|
80
|
-
)
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
print(table.concat(resultBuffer, "\n"))
|
|
84
|
-
|
|
85
|
-
if results.failureCount > 0 then
|
|
86
|
-
print(("%d test nodes reported failures."):format(results.failureCount))
|
|
87
|
-
end
|
|
88
|
-
|
|
89
|
-
if #results.errors > 0 then
|
|
90
|
-
print("Errors reported by tests:")
|
|
91
|
-
print("")
|
|
92
|
-
|
|
93
|
-
for _, message in ipairs(results.errors) do
|
|
94
|
-
TestService:Error(message)
|
|
95
|
-
|
|
96
|
-
-- Insert a blank line after each error
|
|
97
|
-
print("")
|
|
98
|
-
end
|
|
99
|
-
end
|
|
100
|
-
end
|
|
101
|
-
|
|
1
|
+
local TestService = game:GetService("TestService")
|
|
2
|
+
|
|
3
|
+
local TestEnum = require(script.Parent.Parent.TestEnum)
|
|
4
|
+
|
|
5
|
+
local TeamCityReporter = {}
|
|
6
|
+
|
|
7
|
+
local function teamCityEscape(str)
|
|
8
|
+
str = string.gsub(str, "([]|'[])","|%1")
|
|
9
|
+
str = string.gsub(str, "\r", "|r")
|
|
10
|
+
str = string.gsub(str, "\n", "|n")
|
|
11
|
+
return str
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
local function teamCityEnterSuite(suiteName)
|
|
15
|
+
return string.format("##teamcity[testSuiteStarted name='%s']", teamCityEscape(suiteName))
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
local function teamCityLeaveSuite(suiteName)
|
|
19
|
+
return string.format("##teamcity[testSuiteFinished name='%s']", teamCityEscape(suiteName))
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
local function teamCityEnterCase(caseName)
|
|
23
|
+
return string.format("##teamcity[testStarted name='%s']", teamCityEscape(caseName))
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
local function teamCityLeaveCase(caseName)
|
|
27
|
+
return string.format("##teamcity[testFinished name='%s']", teamCityEscape(caseName))
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
local function teamCityFailCase(caseName, errorMessage)
|
|
31
|
+
return string.format("##teamcity[testFailed name='%s' message='%s']",
|
|
32
|
+
teamCityEscape(caseName), teamCityEscape(errorMessage))
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
local function reportNode(node, buffer, level)
|
|
36
|
+
buffer = buffer or {}
|
|
37
|
+
level = level or 0
|
|
38
|
+
if node.status == TestEnum.TestStatus.Skipped then
|
|
39
|
+
return buffer
|
|
40
|
+
end
|
|
41
|
+
if node.planNode.type == TestEnum.NodeType.Describe then
|
|
42
|
+
table.insert(buffer, teamCityEnterSuite(node.planNode.phrase))
|
|
43
|
+
for _, child in ipairs(node.children) do
|
|
44
|
+
reportNode(child, buffer, level + 1)
|
|
45
|
+
end
|
|
46
|
+
table.insert(buffer, teamCityLeaveSuite(node.planNode.phrase))
|
|
47
|
+
else
|
|
48
|
+
table.insert(buffer, teamCityEnterCase(node.planNode.phrase))
|
|
49
|
+
if node.status == TestEnum.TestStatus.Failure then
|
|
50
|
+
table.insert(buffer, teamCityFailCase(node.planNode.phrase, table.concat(node.errors,"\n")))
|
|
51
|
+
end
|
|
52
|
+
table.insert(buffer, teamCityLeaveCase(node.planNode.phrase))
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
local function reportRoot(node)
|
|
57
|
+
local buffer = {}
|
|
58
|
+
|
|
59
|
+
for _, child in ipairs(node.children) do
|
|
60
|
+
reportNode(child, buffer, 0)
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
return buffer
|
|
64
|
+
end
|
|
65
|
+
|
|
66
|
+
local function report(root)
|
|
67
|
+
local buffer = reportRoot(root)
|
|
68
|
+
|
|
69
|
+
return table.concat(buffer, "\n")
|
|
70
|
+
end
|
|
71
|
+
|
|
72
|
+
function TeamCityReporter.report(results)
|
|
73
|
+
local resultBuffer = {
|
|
74
|
+
"Test results:",
|
|
75
|
+
report(results),
|
|
76
|
+
("%d passed, %d failed, %d skipped"):format(
|
|
77
|
+
results.successCount,
|
|
78
|
+
results.failureCount,
|
|
79
|
+
results.skippedCount
|
|
80
|
+
)
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
print(table.concat(resultBuffer, "\n"))
|
|
84
|
+
|
|
85
|
+
if results.failureCount > 0 then
|
|
86
|
+
print(("%d test nodes reported failures."):format(results.failureCount))
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
if #results.errors > 0 then
|
|
90
|
+
print("Errors reported by tests:")
|
|
91
|
+
print("")
|
|
92
|
+
|
|
93
|
+
for _, message in ipairs(results.errors) do
|
|
94
|
+
TestService:Error(message)
|
|
95
|
+
|
|
96
|
+
-- Insert a blank line after each error
|
|
97
|
+
print("")
|
|
98
|
+
end
|
|
99
|
+
end
|
|
100
|
+
end
|
|
101
|
+
|
|
102
102
|
return TeamCityReporter
|
|
@@ -1,106 +1,106 @@
|
|
|
1
|
-
--[[
|
|
2
|
-
The TextReporter uses the results from a completed test to output text to
|
|
3
|
-
standard output and TestService.
|
|
4
|
-
]]
|
|
5
|
-
|
|
6
|
-
local TestService = game:GetService("TestService")
|
|
7
|
-
|
|
8
|
-
local TestEnum = require(script.Parent.Parent.TestEnum)
|
|
9
|
-
|
|
10
|
-
local INDENT = (" "):rep(3)
|
|
11
|
-
local STATUS_SYMBOLS = {
|
|
12
|
-
[TestEnum.TestStatus.Success] = "+",
|
|
13
|
-
[TestEnum.TestStatus.Failure] = "-",
|
|
14
|
-
[TestEnum.TestStatus.Skipped] = "~"
|
|
15
|
-
}
|
|
16
|
-
local UNKNOWN_STATUS_SYMBOL = "?"
|
|
17
|
-
|
|
18
|
-
local TextReporter = {}
|
|
19
|
-
|
|
20
|
-
local function compareNodes(a, b)
|
|
21
|
-
return a.planNode.phrase:lower() < b.planNode.phrase:lower()
|
|
22
|
-
end
|
|
23
|
-
|
|
24
|
-
local function reportNode(node, buffer, level)
|
|
25
|
-
buffer = buffer or {}
|
|
26
|
-
level = level or 0
|
|
27
|
-
|
|
28
|
-
if node.status == TestEnum.TestStatus.Skipped then
|
|
29
|
-
return buffer
|
|
30
|
-
end
|
|
31
|
-
|
|
32
|
-
local line
|
|
33
|
-
|
|
34
|
-
if node.status then
|
|
35
|
-
local symbol = STATUS_SYMBOLS[node.status] or UNKNOWN_STATUS_SYMBOL
|
|
36
|
-
|
|
37
|
-
line = ("%s[%s] %s"):format(
|
|
38
|
-
INDENT:rep(level),
|
|
39
|
-
symbol,
|
|
40
|
-
node.planNode.phrase
|
|
41
|
-
)
|
|
42
|
-
else
|
|
43
|
-
line = ("%s%s"):format(
|
|
44
|
-
INDENT:rep(level),
|
|
45
|
-
node.planNode.phrase
|
|
46
|
-
)
|
|
47
|
-
end
|
|
48
|
-
|
|
49
|
-
table.insert(buffer, line)
|
|
50
|
-
table.sort(node.children, compareNodes)
|
|
51
|
-
|
|
52
|
-
for _, child in ipairs(node.children) do
|
|
53
|
-
reportNode(child, buffer, level + 1)
|
|
54
|
-
end
|
|
55
|
-
|
|
56
|
-
return buffer
|
|
57
|
-
end
|
|
58
|
-
|
|
59
|
-
local function reportRoot(node)
|
|
60
|
-
local buffer = {}
|
|
61
|
-
table.sort(node.children, compareNodes)
|
|
62
|
-
|
|
63
|
-
for _, child in ipairs(node.children) do
|
|
64
|
-
reportNode(child, buffer, 0)
|
|
65
|
-
end
|
|
66
|
-
|
|
67
|
-
return buffer
|
|
68
|
-
end
|
|
69
|
-
|
|
70
|
-
local function report(root)
|
|
71
|
-
local buffer = reportRoot(root)
|
|
72
|
-
|
|
73
|
-
return table.concat(buffer, "\n")
|
|
74
|
-
end
|
|
75
|
-
|
|
76
|
-
function TextReporter.report(results)
|
|
77
|
-
local resultBuffer = {
|
|
78
|
-
"Test results:",
|
|
79
|
-
report(results),
|
|
80
|
-
("%d passed, %d failed, %d skipped"):format(
|
|
81
|
-
results.successCount,
|
|
82
|
-
results.failureCount,
|
|
83
|
-
results.skippedCount
|
|
84
|
-
)
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
print(table.concat(resultBuffer, "\n"))
|
|
88
|
-
|
|
89
|
-
if results.failureCount > 0 then
|
|
90
|
-
print(("%d test nodes reported failures."):format(results.failureCount))
|
|
91
|
-
end
|
|
92
|
-
|
|
93
|
-
if #results.errors > 0 then
|
|
94
|
-
print("Errors reported by tests:")
|
|
95
|
-
print("")
|
|
96
|
-
|
|
97
|
-
for _, message in ipairs(results.errors) do
|
|
98
|
-
TestService:Error(message)
|
|
99
|
-
|
|
100
|
-
-- Insert a blank line after each error
|
|
101
|
-
print("")
|
|
102
|
-
end
|
|
103
|
-
end
|
|
104
|
-
end
|
|
105
|
-
|
|
1
|
+
--[[
|
|
2
|
+
The TextReporter uses the results from a completed test to output text to
|
|
3
|
+
standard output and TestService.
|
|
4
|
+
]]
|
|
5
|
+
|
|
6
|
+
local TestService = game:GetService("TestService")
|
|
7
|
+
|
|
8
|
+
local TestEnum = require(script.Parent.Parent.TestEnum)
|
|
9
|
+
|
|
10
|
+
local INDENT = (" "):rep(3)
|
|
11
|
+
local STATUS_SYMBOLS = {
|
|
12
|
+
[TestEnum.TestStatus.Success] = "+",
|
|
13
|
+
[TestEnum.TestStatus.Failure] = "-",
|
|
14
|
+
[TestEnum.TestStatus.Skipped] = "~"
|
|
15
|
+
}
|
|
16
|
+
local UNKNOWN_STATUS_SYMBOL = "?"
|
|
17
|
+
|
|
18
|
+
local TextReporter = {}
|
|
19
|
+
|
|
20
|
+
local function compareNodes(a, b)
|
|
21
|
+
return a.planNode.phrase:lower() < b.planNode.phrase:lower()
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
local function reportNode(node, buffer, level)
|
|
25
|
+
buffer = buffer or {}
|
|
26
|
+
level = level or 0
|
|
27
|
+
|
|
28
|
+
if node.status == TestEnum.TestStatus.Skipped then
|
|
29
|
+
return buffer
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
local line
|
|
33
|
+
|
|
34
|
+
if node.status then
|
|
35
|
+
local symbol = STATUS_SYMBOLS[node.status] or UNKNOWN_STATUS_SYMBOL
|
|
36
|
+
|
|
37
|
+
line = ("%s[%s] %s"):format(
|
|
38
|
+
INDENT:rep(level),
|
|
39
|
+
symbol,
|
|
40
|
+
node.planNode.phrase
|
|
41
|
+
)
|
|
42
|
+
else
|
|
43
|
+
line = ("%s%s"):format(
|
|
44
|
+
INDENT:rep(level),
|
|
45
|
+
node.planNode.phrase
|
|
46
|
+
)
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
table.insert(buffer, line)
|
|
50
|
+
table.sort(node.children, compareNodes)
|
|
51
|
+
|
|
52
|
+
for _, child in ipairs(node.children) do
|
|
53
|
+
reportNode(child, buffer, level + 1)
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
return buffer
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
local function reportRoot(node)
|
|
60
|
+
local buffer = {}
|
|
61
|
+
table.sort(node.children, compareNodes)
|
|
62
|
+
|
|
63
|
+
for _, child in ipairs(node.children) do
|
|
64
|
+
reportNode(child, buffer, 0)
|
|
65
|
+
end
|
|
66
|
+
|
|
67
|
+
return buffer
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
local function report(root)
|
|
71
|
+
local buffer = reportRoot(root)
|
|
72
|
+
|
|
73
|
+
return table.concat(buffer, "\n")
|
|
74
|
+
end
|
|
75
|
+
|
|
76
|
+
function TextReporter.report(results)
|
|
77
|
+
local resultBuffer = {
|
|
78
|
+
"Test results:",
|
|
79
|
+
report(results),
|
|
80
|
+
("%d passed, %d failed, %d skipped"):format(
|
|
81
|
+
results.successCount,
|
|
82
|
+
results.failureCount,
|
|
83
|
+
results.skippedCount
|
|
84
|
+
)
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
print(table.concat(resultBuffer, "\n"))
|
|
88
|
+
|
|
89
|
+
if results.failureCount > 0 then
|
|
90
|
+
print(("%d test nodes reported failures."):format(results.failureCount))
|
|
91
|
+
end
|
|
92
|
+
|
|
93
|
+
if #results.errors > 0 then
|
|
94
|
+
print("Errors reported by tests:")
|
|
95
|
+
print("")
|
|
96
|
+
|
|
97
|
+
for _, message in ipairs(results.errors) do
|
|
98
|
+
TestService:Error(message)
|
|
99
|
+
|
|
100
|
+
-- Insert a blank line after each error
|
|
101
|
+
print("")
|
|
102
|
+
end
|
|
103
|
+
end
|
|
104
|
+
end
|
|
105
|
+
|
|
106
106
|
return TextReporter
|