@holoscript/core 2.0.1 → 2.1.0
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/dist/chunk-2XXE34KS.js +344 -0
- package/dist/chunk-2XXE34KS.js.map +1 -0
- package/dist/chunk-3X2EGU7Z.cjs +52 -0
- package/dist/chunk-3X2EGU7Z.cjs.map +1 -0
- package/dist/chunk-AFFVFO4D.js +1689 -0
- package/dist/chunk-AFFVFO4D.js.map +1 -0
- package/dist/chunk-DGUM43GV.js +10 -0
- package/dist/chunk-DGUM43GV.js.map +1 -0
- package/{src/HoloScriptDebugger.ts → dist/chunk-DOY73HDH.js} +118 -257
- package/dist/chunk-DOY73HDH.js.map +1 -0
- package/dist/chunk-JEQ2X3Z6.cjs +12 -0
- package/dist/chunk-JEQ2X3Z6.cjs.map +1 -0
- package/dist/chunk-L6VLNVKP.cjs +1691 -0
- package/dist/chunk-L6VLNVKP.cjs.map +1 -0
- package/dist/chunk-MFNO57XL.cjs +347 -0
- package/dist/chunk-MFNO57XL.cjs.map +1 -0
- package/dist/chunk-R75MREOS.cjs +424 -0
- package/dist/chunk-R75MREOS.cjs.map +1 -0
- package/dist/chunk-SATNCODL.js +45 -0
- package/dist/chunk-SATNCODL.js.map +1 -0
- package/dist/chunk-T57ZL7KR.cjs +1281 -0
- package/dist/chunk-T57ZL7KR.cjs.map +1 -0
- package/dist/chunk-U72GEJZT.js +1279 -0
- package/dist/chunk-U72GEJZT.js.map +1 -0
- package/dist/debugger.cjs +20 -0
- package/dist/debugger.cjs.map +1 -0
- package/dist/debugger.d.cts +171 -0
- package/dist/debugger.d.ts +171 -0
- package/dist/debugger.js +7 -0
- package/dist/debugger.js.map +1 -0
- package/dist/index.cjs +6803 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +4093 -0
- package/dist/index.d.ts +4093 -0
- package/dist/index.js +6715 -0
- package/dist/index.js.map +1 -0
- package/dist/parser.cjs +14 -0
- package/dist/parser.cjs.map +1 -0
- package/dist/parser.d.cts +172 -0
- package/dist/parser.d.ts +172 -0
- package/dist/parser.js +5 -0
- package/dist/parser.js.map +1 -0
- package/dist/runtime.cjs +14 -0
- package/dist/runtime.cjs.map +1 -0
- package/dist/runtime.d.cts +200 -0
- package/dist/runtime.d.ts +200 -0
- package/dist/runtime.js +5 -0
- package/dist/runtime.js.map +1 -0
- package/dist/type-checker.cjs +17 -0
- package/dist/type-checker.cjs.map +1 -0
- package/dist/type-checker.d.cts +105 -0
- package/dist/type-checker.d.ts +105 -0
- package/dist/type-checker.js +4 -0
- package/dist/type-checker.js.map +1 -0
- package/dist/types-4h8cbtF_.d.cts +329 -0
- package/dist/types-4h8cbtF_.d.ts +329 -0
- package/package.json +17 -13
- package/src/HoloScript2DParser.js +0 -227
- package/src/HoloScript2DParser.ts +0 -261
- package/src/HoloScriptCodeParser.js +0 -1102
- package/src/HoloScriptCodeParser.ts +0 -1188
- package/src/HoloScriptDebugger.js +0 -458
- package/src/HoloScriptParser.js +0 -338
- package/src/HoloScriptParser.ts +0 -397
- package/src/HoloScriptPlusParser.js +0 -371
- package/src/HoloScriptPlusParser.ts +0 -543
- package/src/HoloScriptRuntime.js +0 -1399
- package/src/HoloScriptRuntime.test.js +0 -351
- package/src/HoloScriptRuntime.test.ts +0 -436
- package/src/HoloScriptRuntime.ts +0 -1653
- package/src/HoloScriptTypeChecker.js +0 -356
- package/src/HoloScriptTypeChecker.ts +0 -475
- package/src/__tests__/GraphicsServices.test.js +0 -357
- package/src/__tests__/GraphicsServices.test.ts +0 -427
- package/src/__tests__/HoloScriptPlusParser.test.js +0 -317
- package/src/__tests__/HoloScriptPlusParser.test.ts +0 -392
- package/src/__tests__/integration.test.js +0 -336
- package/src/__tests__/integration.test.ts +0 -416
- package/src/__tests__/performance.bench.js +0 -218
- package/src/__tests__/performance.bench.ts +0 -262
- package/src/__tests__/type-checker.test.js +0 -60
- package/src/__tests__/type-checker.test.ts +0 -73
- package/src/index.js +0 -217
- package/src/index.ts +0 -426
- package/src/interop/Interoperability.js +0 -413
- package/src/interop/Interoperability.ts +0 -494
- package/src/logger.js +0 -42
- package/src/logger.ts +0 -57
- package/src/parser/EnhancedParser.js +0 -205
- package/src/parser/EnhancedParser.ts +0 -251
- package/src/parser/HoloScriptPlusParser.js +0 -928
- package/src/parser/HoloScriptPlusParser.ts +0 -1089
- package/src/runtime/HoloScriptPlusRuntime.js +0 -674
- package/src/runtime/HoloScriptPlusRuntime.ts +0 -861
- package/src/runtime/PerformanceTelemetry.js +0 -323
- package/src/runtime/PerformanceTelemetry.ts +0 -467
- package/src/runtime/RuntimeOptimization.js +0 -361
- package/src/runtime/RuntimeOptimization.ts +0 -416
- package/src/services/HololandGraphicsPipelineService.js +0 -506
- package/src/services/HololandGraphicsPipelineService.ts +0 -662
- package/src/services/PlatformPerformanceOptimizer.js +0 -356
- package/src/services/PlatformPerformanceOptimizer.ts +0 -503
- package/src/state/ReactiveState.js +0 -427
- package/src/state/ReactiveState.ts +0 -572
- package/src/tools/DeveloperExperience.js +0 -376
- package/src/tools/DeveloperExperience.ts +0 -438
- package/src/traits/AIDriverTrait.js +0 -322
- package/src/traits/AIDriverTrait.test.js +0 -329
- package/src/traits/AIDriverTrait.test.ts +0 -357
- package/src/traits/AIDriverTrait.ts +0 -474
- package/src/traits/LightingTrait.js +0 -313
- package/src/traits/LightingTrait.test.js +0 -410
- package/src/traits/LightingTrait.test.ts +0 -462
- package/src/traits/LightingTrait.ts +0 -505
- package/src/traits/MaterialTrait.js +0 -194
- package/src/traits/MaterialTrait.test.js +0 -286
- package/src/traits/MaterialTrait.test.ts +0 -329
- package/src/traits/MaterialTrait.ts +0 -324
- package/src/traits/RenderingTrait.js +0 -356
- package/src/traits/RenderingTrait.test.js +0 -363
- package/src/traits/RenderingTrait.test.ts +0 -427
- package/src/traits/RenderingTrait.ts +0 -555
- package/src/traits/VRTraitSystem.js +0 -740
- package/src/traits/VRTraitSystem.ts +0 -1040
- package/src/traits/VoiceInputTrait.js +0 -284
- package/src/traits/VoiceInputTrait.test.js +0 -226
- package/src/traits/VoiceInputTrait.test.ts +0 -252
- package/src/traits/VoiceInputTrait.ts +0 -401
- package/src/types/AdvancedTypeSystem.js +0 -226
- package/src/types/AdvancedTypeSystem.ts +0 -494
- package/src/types/HoloScriptPlus.d.ts +0 -853
- package/src/types.js +0 -6
- package/src/types.ts +0 -369
- package/tsconfig.json +0 -23
- package/tsup.config.d.ts +0 -2
- package/tsup.config.js +0 -18
- package/tsup.config.ts +0 -19
|
@@ -1,357 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* AIDriverTrait Tests
|
|
3
|
-
*
|
|
4
|
-
* Comprehensive tests for AI-driven NPC behavior
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { describe, it, expect, beforeEach, vi } from 'vitest';
|
|
8
|
-
import { AIDriverTrait, type AIDriverConfig, type BehaviorNode, type NPCGoal } from '../traits/AIDriverTrait';
|
|
9
|
-
|
|
10
|
-
describe('AIDriverTrait', () => {
|
|
11
|
-
let trait: AIDriverTrait;
|
|
12
|
-
let config: AIDriverConfig;
|
|
13
|
-
|
|
14
|
-
beforeEach(() => {
|
|
15
|
-
config = {
|
|
16
|
-
npcId: 'npc-001',
|
|
17
|
-
decisionMode: 'hybrid',
|
|
18
|
-
personality: {
|
|
19
|
-
sociability: 0.8,
|
|
20
|
-
aggression: 0.2,
|
|
21
|
-
curiosity: 0.9,
|
|
22
|
-
loyalty: 0.7,
|
|
23
|
-
},
|
|
24
|
-
stimuliThresholds: {
|
|
25
|
-
hearing: 50,
|
|
26
|
-
sight: 100,
|
|
27
|
-
touch: 5,
|
|
28
|
-
},
|
|
29
|
-
};
|
|
30
|
-
trait = new AIDriverTrait(config);
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
describe('Initialization', () => {
|
|
34
|
-
it('should initialize with config', () => {
|
|
35
|
-
expect(trait).toBeDefined();
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it('should set NPC ID', () => {
|
|
39
|
-
expect(trait).toBeDefined();
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it('should accept decision modes', () => {
|
|
43
|
-
const modes = ['reactive', 'goal-driven', 'learning', 'hybrid'] as const;
|
|
44
|
-
for (const mode of modes) {
|
|
45
|
-
const modeConfig = { ...config, decisionMode: mode };
|
|
46
|
-
const modeTrait = new AIDriverTrait(modeConfig);
|
|
47
|
-
expect(modeTrait).toBeDefined();
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
describe('Personality Configuration', () => {
|
|
53
|
-
it('should accept personality traits', () => {
|
|
54
|
-
const personalityConfig: AIDriverConfig = {
|
|
55
|
-
npcId: 'npc-friendly',
|
|
56
|
-
decisionMode: 'hybrid',
|
|
57
|
-
personality: {
|
|
58
|
-
sociability: 1.0,
|
|
59
|
-
aggression: 0.0,
|
|
60
|
-
curiosity: 0.5,
|
|
61
|
-
loyalty: 1.0,
|
|
62
|
-
},
|
|
63
|
-
};
|
|
64
|
-
const friendlyNPC = new AIDriverTrait(personalityConfig);
|
|
65
|
-
expect(friendlyNPC).toBeDefined();
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it('should have default personality if not specified', () => {
|
|
69
|
-
const minimalConfig: AIDriverConfig = {
|
|
70
|
-
npcId: 'npc-default',
|
|
71
|
-
decisionMode: 'reactive',
|
|
72
|
-
};
|
|
73
|
-
const defaultNPC = new AIDriverTrait(minimalConfig);
|
|
74
|
-
expect(defaultNPC).toBeDefined();
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
it('should validate personality values 0-1', () => {
|
|
78
|
-
const validConfig: AIDriverConfig = {
|
|
79
|
-
npcId: 'npc-valid',
|
|
80
|
-
decisionMode: 'hybrid',
|
|
81
|
-
personality: {
|
|
82
|
-
sociability: 0.5,
|
|
83
|
-
aggression: 0.5,
|
|
84
|
-
curiosity: 0.5,
|
|
85
|
-
loyalty: 0.5,
|
|
86
|
-
},
|
|
87
|
-
};
|
|
88
|
-
const validNPC = new AIDriverTrait(validConfig);
|
|
89
|
-
expect(validNPC).toBeDefined();
|
|
90
|
-
});
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
describe('Stimuli Perception', () => {
|
|
94
|
-
it('should support custom stimulus thresholds', () => {
|
|
95
|
-
const customConfig: AIDriverConfig = {
|
|
96
|
-
npcId: 'npc-sharp-senses',
|
|
97
|
-
decisionMode: 'reactive',
|
|
98
|
-
stimuliThresholds: {
|
|
99
|
-
hearing: 200,
|
|
100
|
-
sight: 300,
|
|
101
|
-
touch: 10,
|
|
102
|
-
},
|
|
103
|
-
};
|
|
104
|
-
const sensitivNPC = new AIDriverTrait(customConfig);
|
|
105
|
-
expect(sensitivNPC).toBeDefined();
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
it('should have default thresholds if not specified', () => {
|
|
109
|
-
const minimalConfig: AIDriverConfig = {
|
|
110
|
-
npcId: 'npc-minimal',
|
|
111
|
-
decisionMode: 'reactive',
|
|
112
|
-
};
|
|
113
|
-
const defaultNPC = new AIDriverTrait(minimalConfig);
|
|
114
|
-
expect(defaultNPC).toBeDefined();
|
|
115
|
-
});
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
describe('Behavior Trees', () => {
|
|
119
|
-
it('should accept behavior tree configuration', () => {
|
|
120
|
-
const behaviorTree: BehaviorNode = {
|
|
121
|
-
id: 'root',
|
|
122
|
-
type: 'selector',
|
|
123
|
-
children: [
|
|
124
|
-
{
|
|
125
|
-
id: 'idle',
|
|
126
|
-
type: 'action',
|
|
127
|
-
action: async () => true,
|
|
128
|
-
},
|
|
129
|
-
],
|
|
130
|
-
};
|
|
131
|
-
const behaviorConfig: AIDriverConfig = {
|
|
132
|
-
npcId: 'npc-behavioral',
|
|
133
|
-
decisionMode: 'reactive',
|
|
134
|
-
behaviorTree,
|
|
135
|
-
};
|
|
136
|
-
const behaviorNPC = new AIDriverTrait(behaviorConfig);
|
|
137
|
-
expect(behaviorNPC).toBeDefined();
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
it('should support sequence nodes', () => {
|
|
141
|
-
const sequenceTree: BehaviorNode = {
|
|
142
|
-
id: 'sequence',
|
|
143
|
-
type: 'sequence',
|
|
144
|
-
children: [
|
|
145
|
-
{ id: 'step1', type: 'action', action: async () => true },
|
|
146
|
-
{ id: 'step2', type: 'action', action: async () => true },
|
|
147
|
-
],
|
|
148
|
-
};
|
|
149
|
-
expect(sequenceTree).toBeDefined();
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
it('should support selector nodes', () => {
|
|
153
|
-
const selectorTree: BehaviorNode = {
|
|
154
|
-
id: 'selector',
|
|
155
|
-
type: 'selector',
|
|
156
|
-
children: [
|
|
157
|
-
{ id: 'option1', type: 'action', action: async () => false },
|
|
158
|
-
{ id: 'option2', type: 'action', action: async () => true },
|
|
159
|
-
],
|
|
160
|
-
};
|
|
161
|
-
expect(selectorTree).toBeDefined();
|
|
162
|
-
});
|
|
163
|
-
|
|
164
|
-
it('should support parallel nodes', () => {
|
|
165
|
-
const parallelTree: BehaviorNode = {
|
|
166
|
-
id: 'parallel',
|
|
167
|
-
type: 'parallel',
|
|
168
|
-
children: [
|
|
169
|
-
{ id: 'task1', type: 'action', action: async () => true },
|
|
170
|
-
{ id: 'task2', type: 'action', action: async () => true },
|
|
171
|
-
],
|
|
172
|
-
};
|
|
173
|
-
expect(parallelTree).toBeDefined();
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
it('should support condition nodes', () => {
|
|
177
|
-
const conditionTree: BehaviorNode = {
|
|
178
|
-
id: 'condition',
|
|
179
|
-
type: 'condition',
|
|
180
|
-
condition: () => true,
|
|
181
|
-
};
|
|
182
|
-
expect(conditionTree).toBeDefined();
|
|
183
|
-
});
|
|
184
|
-
});
|
|
185
|
-
|
|
186
|
-
describe('Goal Planning (GOAP)', () => {
|
|
187
|
-
it('should accept goals configuration', () => {
|
|
188
|
-
const goals: NPCGoal[] = [
|
|
189
|
-
{
|
|
190
|
-
id: 'explore',
|
|
191
|
-
name: 'Explore Area',
|
|
192
|
-
priority: 0.5,
|
|
193
|
-
preconditions: new Map([['energy', 50]]),
|
|
194
|
-
effects: new Map([['discovered', true]]),
|
|
195
|
-
cost: 10,
|
|
196
|
-
},
|
|
197
|
-
];
|
|
198
|
-
const goalConfig: AIDriverConfig = {
|
|
199
|
-
npcId: 'npc-planner',
|
|
200
|
-
decisionMode: 'goal-driven',
|
|
201
|
-
goals,
|
|
202
|
-
};
|
|
203
|
-
const plannerNPC = new AIDriverTrait(goalConfig);
|
|
204
|
-
expect(plannerNPC).toBeDefined();
|
|
205
|
-
});
|
|
206
|
-
|
|
207
|
-
it('should support multiple goals with priorities', () => {
|
|
208
|
-
const goals: NPCGoal[] = [
|
|
209
|
-
{
|
|
210
|
-
id: 'survive',
|
|
211
|
-
name: 'Survive',
|
|
212
|
-
priority: 1.0,
|
|
213
|
-
preconditions: new Map(),
|
|
214
|
-
effects: new Map([['alive', true]]),
|
|
215
|
-
cost: 5,
|
|
216
|
-
},
|
|
217
|
-
{
|
|
218
|
-
id: 'succeed',
|
|
219
|
-
name: 'Succeed',
|
|
220
|
-
priority: 0.8,
|
|
221
|
-
preconditions: new Map([['alive', true]]),
|
|
222
|
-
effects: new Map([['succeeded', true]]),
|
|
223
|
-
cost: 20,
|
|
224
|
-
},
|
|
225
|
-
];
|
|
226
|
-
expect(goals.length).toBe(2);
|
|
227
|
-
});
|
|
228
|
-
|
|
229
|
-
it('should support goal timeouts', () => {
|
|
230
|
-
const timedGoal: NPCGoal = {
|
|
231
|
-
id: 'escape',
|
|
232
|
-
name: 'Escape Danger',
|
|
233
|
-
priority: 0.9,
|
|
234
|
-
preconditions: new Map([['threatened', true]]),
|
|
235
|
-
effects: new Map([['safe', true]]),
|
|
236
|
-
cost: 15,
|
|
237
|
-
timeoutMs: 5000,
|
|
238
|
-
};
|
|
239
|
-
expect(timedGoal.timeoutMs).toBe(5000);
|
|
240
|
-
});
|
|
241
|
-
});
|
|
242
|
-
|
|
243
|
-
describe('Learning Configuration', () => {
|
|
244
|
-
it('should support learning mode', () => {
|
|
245
|
-
const learningConfig: AIDriverConfig = {
|
|
246
|
-
npcId: 'npc-learner',
|
|
247
|
-
decisionMode: 'learning',
|
|
248
|
-
enableLearning: true,
|
|
249
|
-
learningRate: 0.1,
|
|
250
|
-
};
|
|
251
|
-
const learnerNPC = new AIDriverTrait(learningConfig);
|
|
252
|
-
expect(learnerNPC).toBeDefined();
|
|
253
|
-
});
|
|
254
|
-
|
|
255
|
-
it('should allow disabling learning', () => {
|
|
256
|
-
const noLearningConfig: AIDriverConfig = {
|
|
257
|
-
npcId: 'npc-fixed',
|
|
258
|
-
decisionMode: 'reactive',
|
|
259
|
-
enableLearning: false,
|
|
260
|
-
};
|
|
261
|
-
const staticNPC = new AIDriverTrait(noLearningConfig);
|
|
262
|
-
expect(staticNPC).toBeDefined();
|
|
263
|
-
});
|
|
264
|
-
|
|
265
|
-
it('should accept custom learning rate', () => {
|
|
266
|
-
const fastLearning: AIDriverConfig = {
|
|
267
|
-
npcId: 'npc-fast',
|
|
268
|
-
decisionMode: 'learning',
|
|
269
|
-
enableLearning: true,
|
|
270
|
-
learningRate: 0.5,
|
|
271
|
-
};
|
|
272
|
-
const slowLearning: AIDriverConfig = {
|
|
273
|
-
npcId: 'npc-slow',
|
|
274
|
-
decisionMode: 'learning',
|
|
275
|
-
enableLearning: true,
|
|
276
|
-
learningRate: 0.01,
|
|
277
|
-
};
|
|
278
|
-
expect(fastLearning.learningRate).toBeGreaterThan(slowLearning.learningRate);
|
|
279
|
-
});
|
|
280
|
-
});
|
|
281
|
-
|
|
282
|
-
describe('uaa2 Agent Integration', () => {
|
|
283
|
-
it('should accept uaa2 agent ID', () => {
|
|
284
|
-
const uaa2Config: AIDriverConfig = {
|
|
285
|
-
npcId: 'npc-integrated',
|
|
286
|
-
decisionMode: 'hybrid',
|
|
287
|
-
agentId: 'agent-001',
|
|
288
|
-
};
|
|
289
|
-
const integratedNPC = new AIDriverTrait(uaa2Config);
|
|
290
|
-
expect(integratedNPC).toBeDefined();
|
|
291
|
-
});
|
|
292
|
-
|
|
293
|
-
it('should work without uaa2 integration', () => {
|
|
294
|
-
const standaloneConfig: AIDriverConfig = {
|
|
295
|
-
npcId: 'npc-standalone',
|
|
296
|
-
decisionMode: 'reactive',
|
|
297
|
-
};
|
|
298
|
-
const standaloneNPC = new AIDriverTrait(standaloneConfig);
|
|
299
|
-
expect(standaloneNPC).toBeDefined();
|
|
300
|
-
});
|
|
301
|
-
});
|
|
302
|
-
|
|
303
|
-
describe('Decision Modes', () => {
|
|
304
|
-
it('should support reactive decision making', () => {
|
|
305
|
-
const reactiveConfig: AIDriverConfig = {
|
|
306
|
-
npcId: 'npc-reactive',
|
|
307
|
-
decisionMode: 'reactive',
|
|
308
|
-
};
|
|
309
|
-
const reactiveNPC = new AIDriverTrait(reactiveConfig);
|
|
310
|
-
expect(reactiveNPC).toBeDefined();
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
it('should support goal-driven decision making', () => {
|
|
314
|
-
const goalConfig: AIDriverConfig = {
|
|
315
|
-
npcId: 'npc-goal',
|
|
316
|
-
decisionMode: 'goal-driven',
|
|
317
|
-
goals: [
|
|
318
|
-
{
|
|
319
|
-
id: 'goal1',
|
|
320
|
-
name: 'Goal 1',
|
|
321
|
-
priority: 0.8,
|
|
322
|
-
preconditions: new Map(),
|
|
323
|
-
effects: new Map(),
|
|
324
|
-
cost: 10,
|
|
325
|
-
},
|
|
326
|
-
],
|
|
327
|
-
};
|
|
328
|
-
const goalNPC = new AIDriverTrait(goalConfig);
|
|
329
|
-
expect(goalNPC).toBeDefined();
|
|
330
|
-
});
|
|
331
|
-
|
|
332
|
-
it('should support learning decision making', () => {
|
|
333
|
-
const learningConfig: AIDriverConfig = {
|
|
334
|
-
npcId: 'npc-learning',
|
|
335
|
-
decisionMode: 'learning',
|
|
336
|
-
enableLearning: true,
|
|
337
|
-
};
|
|
338
|
-
const learningNPC = new AIDriverTrait(learningConfig);
|
|
339
|
-
expect(learningNPC).toBeDefined();
|
|
340
|
-
});
|
|
341
|
-
|
|
342
|
-
it('should support hybrid decision making', () => {
|
|
343
|
-
const hybridConfig: AIDriverConfig = {
|
|
344
|
-
npcId: 'npc-hybrid',
|
|
345
|
-
decisionMode: 'hybrid',
|
|
346
|
-
behaviorTree: {
|
|
347
|
-
id: 'root',
|
|
348
|
-
type: 'selector',
|
|
349
|
-
},
|
|
350
|
-
goals: [],
|
|
351
|
-
enableLearning: true,
|
|
352
|
-
};
|
|
353
|
-
const hybridNPC = new AIDriverTrait(hybridConfig);
|
|
354
|
-
expect(hybridNPC).toBeDefined();
|
|
355
|
-
});
|
|
356
|
-
});
|
|
357
|
-
});
|