diff options
| author | JAROWMR <jarorutjes07@gmail.com> | 2024-11-10 16:08:22 +0100 | 
|---|---|---|
| committer | JAROWMR <jarorutjes07@gmail.com> | 2024-11-10 16:08:22 +0100 | 
| commit | b48773d19961be44bf9edd7a326dd85f304828f4 (patch) | |
| tree | f6edeae71454018bf1301ce4b007833a2a1b0fc3 /src/test | |
| parent | 556eb319c9e5c3f6b90e9533eadcdd5682a5d347 (diff) | |
added tests and fixed bugs in system
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/ParticleTest.cpp | 44 | 
1 files changed, 41 insertions, 3 deletions
| diff --git a/src/test/ParticleTest.cpp b/src/test/ParticleTest.cpp index 368a1f6..1b949e3 100644 --- a/src/test/ParticleTest.cpp +++ b/src/test/ParticleTest.cpp @@ -74,8 +74,10 @@ TEST_F(ParticlesTest, spawnParticle) {  	emitter.data.end_lifespan = 5;  	emitter.data.boundary.height = 100;  	emitter.data.boundary.width = 100; -	emitter.data.max_speed = 1; -	emitter.data.max_angle = 1; +	emitter.data.max_speed = 0.1; +	emitter.data.max_angle = 0.1; +	emitter.data.max_speed = 10; +	emitter.data.max_angle = 10;  	particle_system.update();   	//check if nothing happend  	EXPECT_EQ(emitter.data.particles[0].active, 0); @@ -89,7 +91,7 @@ TEST_F(ParticlesTest, spawnParticle) {  	EXPECT_EQ(emitter.data.particles[2].active, 1);  	particle_system.update();  	EXPECT_EQ(emitter.data.particles[3].active, 1); -	 +  	for (auto& particle : emitter.data.particles) {          // Check velocity range          EXPECT_GE(particle.velocity.x, emitter.data.min_speed);  // Speed should be greater than or equal to min_speed @@ -103,3 +105,39 @@ TEST_F(ParticlesTest, spawnParticle) {      }  } + +TEST_F(ParticlesTest, moveParticleHorizontal) { +	Config::get_instance().physics.gravity = 1; +	ComponentManager & mgr = ComponentManager::get_instance(); +	ParticleEmitter & emitter = mgr.get_components_by_id<ParticleEmitter>(0).front().get(); +	emitter.data.end_lifespan = 100; +	emitter.data.boundary.height = 100; +	emitter.data.boundary.width = 100; +	emitter.data.min_speed = 1; +	emitter.data.max_speed = 1; +	emitter.data.max_angle = 0; +	emitter.data.emission_rate = 1; +	for (int a = 1; a < emitter.data.boundary.width/2; a++) { +		particle_system.update();  +		EXPECT_EQ(emitter.data.particles[0].position.x,a); +	} +} + + +TEST_F(ParticlesTest, moveParticleVertical) { +	Config::get_instance().physics.gravity = 1; +	ComponentManager & mgr = ComponentManager::get_instance(); +	ParticleEmitter & emitter = mgr.get_components_by_id<ParticleEmitter>(0).front().get(); +	emitter.data.end_lifespan = 100; +	emitter.data.boundary.height = 100; +	emitter.data.boundary.width = 100; +	emitter.data.min_speed = 1; +	emitter.data.max_speed = 1; +	emitter.data.min_angle = 90; +	emitter.data.max_angle = 90; +	emitter.data.emission_rate = 1; +	for (int a = 1; a < emitter.data.boundary.width/2; a++) { +		particle_system.update();  +		EXPECT_EQ(emitter.data.particles[0].position.y,a); +	} +} |