Saltar al contenido

PropertyDescriptorTester

Abrir en ChatGPT
23.06 Experimental
Java API

El PropertyDescriptorTester en webforJ simplifica las pruebas de componentes web de terceros integrados en su aplicación. Valida que las propiedades definidas con PropertyDescriptor estén correctamente enlazadas a sus métodos getter y setter y asegura que los comportamientos por defecto se manejen de manera consistente. Esta herramienta es especialmente útil para verificar la funcionalidad de las propiedades expuestas por componentes de terceros sin requerir lógica de prueba repetitiva.

característica experimental

El adaptador PropertyDescriptorTester de webforJ es actualmente una característica experimental. Pueden introducirse cambios importantes en cualquier momento.

Resumen

Cuando se trabaja con componentes web de terceros, es esencial garantizar que las propiedades se comporten como se espera. El PropertyDescriptorTester automatiza este proceso validando que las propiedades:

  • Estén correctamente mapeadas a sus métodos getter y setter.
  • Mantengan valores por defecto esperados y comportamientos personalizados.
  • Eviten problemas de integración comunes, como nombres de propiedades incompatibles o valores por defecto inconsistentes.

La herramienta admite anotaciones para casos de uso más complejos, como excluir propiedades irrelevantes o definir métodos getter y setter personalizados, lo que la convierte en una opción versátil para las pruebas de integración.

Cómo funciona el PropertyDescriptorTester

El proceso de prueba involucra varios pasos automatizados:

  1. Escaneo de Clases: El PropertyDescriptorScanner identifica todos los campos PropertyDescriptor dentro de una clase de componente, excluyendo automáticamente los campos anotados con @PropertyExclude.

  2. Resolución de Métodos: Se detectan los métodos getter y setter estándar basados en convenciones de nomenclatura (get<PropertyName>/set<PropertyName>). Para implementaciones no estándar, anotaciones como @PropertyMethods especifican nombres de métodos personalizados o clases objetivo.

  3. Validación: Los valores por defecto se asignan utilizando el método setter, se recuperan con el getter y se comparan para asegurar su corrección. Cualquier discrepancia activa un AssertionError, resaltando el problema específico.

  4. Informe de Errores: El probador proporciona retroalimentación detallada sobre cualquier fallo en la validación, como métodos faltantes, valores por defecto inconsistentes o configuraciones incorrectas de propiedades.

Escribiendo pruebas con PropertyDescriptorTester

Aquí hay un ejemplo que demuestra la validación básica de propiedades para un componente AppLayout:

Ejemplo: Validación básica

MyComponent.java
public class MyComponent extends ElementCompositeContainer {
private final PropertyDescriptor<Boolean> drawerOpened =
PropertyDescriptor.property("drawerOpened", false);
private final PropertyDescriptor<String> headerTitle =
PropertyDescriptor.property("headerTitle", "Título Predeterminado");

// setters y getters
}

Caso de prueba

MyComponentTest.java
import com.webforj.component.element.PropertyDescriptorTester;
import org.junit.jupiter.api.Test;

class MyComponentTest {

MyComponent component = new MyComponent();

@Test
void validateProperties() {
try {
PropertyDescriptorTester.run(MyComponent.class, component);
} catch (Exception e) {
fail("La prueba PropertyDescriptor falló: " + e.getMessage());
}
}
}

Esta prueba verifica automáticamente:

  • Que drawerOpened tenga métodos getter y setter válidos.
  • Que headerTitle tenga como valor por defecto "Título Predeterminado".

Casos de uso avanzados con anotaciones

Para escenarios más complejos, PropertyDescriptorTester admite anotaciones para personalizar o excluir propiedades de las pruebas.

Excluir propiedades con @PropertyExclude

Excluya propiedades que dependen de sistemas externos o que no son relevantes para la prueba. Por ejemplo:

@PropertyExclude
private final PropertyDescriptor<String> excludedProperty =
PropertyDescriptor.property("excludedProperty", "Excluido");

Personalizar métodos con @PropertyMethods

Defina métodos getter, setter o clase objetivo personalizados cuando las convenciones de nomenclatura por defecto no se apliquen:

@PropertyMethods(getter = "retrieveValue", setter = "updateValue", target = InnerClass.class)
private final PropertyDescriptor<String> customProperty =
PropertyDescriptor.property("customProperty", "Valor Predeterminado");