createMock( UserIdentity::class ); $userMock->method( 'getId' )->willReturn( $userId ); return $userMock; } /** * Provides different scenarios for AB test enrollment. */ public function enrollmentProvider(): array { return [ 'Experiment Disabled' => [ [ 'enabled' => false, 'name' => 'mockExperiment' ], // User ID 1, // Expected result true ], 'Experiment Enabled, Wrong Name' => [ [ 'enabled' => true, 'name' => 'mockWrongExperiment' ], 1, true ], 'Experiment Enabled, Correct Name, User in Control Group' => [ [ 'enabled' => true, 'name' => 'mockExperiment' ], 2, false ], 'Experiment Enabled, Correct Name, User in Test Group' => [ [ 'enabled' => true, 'name' => 'mockExperiment' ], 1, true ], ]; } /** * @dataProvider enrollmentProvider * @covers ::isMet */ public function testABRequirement( $experimentConfig, $userId, $expectedResult ) { $config = new HashConfig( [ 'VectorWebABTestEnrollment' => $experimentConfig ] ); $user = $this->createUserMock( $userId ); $abRequirement = new ABRequirement( $config, $user, 'mockExperiment', ); $this->assertEquals( $expectedResult, $abRequirement->isMet() ); } /** * @covers ::getName */ public function testGetName() { $config = new HashConfig(); $user = $this->createUserMock( 0 ); $experimentName = 'mockExperiment'; $name = 'ABTestRequirement'; $abRequirement = new ABRequirement( $config, $user, $experimentName, $name ); $this->assertEquals( $name, $abRequirement->getName() ); } }