Únase a nosotros el 30 de abril: Presentación de la prueba CT de Parasoft C/C++ para pruebas continuas y excelencia en el cumplimiento | Regístrese ahora

Cree entornos de espacio aislado de bajo costo con simulación de API

Foto de cabeza de Grigori Trofimov, arquitecto senior de soluciones de Parasoft
17 de diciembre de 2020
6 min leer

Los sandboxes de desarrollo pueden ser la clave para completar una venta y satisfacer a sus clientes si está en el negocio de las API. Pero, ¿cómo se crea un entorno de sandbox de bajo costo con simulación API? Esta publicación cubre cómo puede comenzar.

Al vender software, especialmente productos empresariales complejos, entendemos que una venta no termina cuando el efectivo llega al banco. El soporte posventa es tan importante como la preventa para la experiencia del cliente. De hecho, el éxito del cliente es lo que impulsa los ingresos y hay una gran cantidad de datos para demostrarlo. Khalid Saleh de Invesp creó un fantástico infografía en este. Aquí hay algunas conclusiones clave:

  • Adquirir un nuevo cliente es cinco veces más caro que retener a un cliente existente.
  • La probabilidad de vender a los clientes existentes es del 60 al 70%, mientras que la probabilidad de vender a un nuevo cliente potencial es del 5 al 20%.
  • Aumentar las tasas de retención de clientes en un 5% aumenta las ganancias entre un 25% y un 95%.

El éxito del cliente es fundamental para los negocios

Básicamente, el éxito del cliente lo es todo en las ventas. Significa que tienes un buen producto. Significa que obtiene clientes potenciales gratuitos, ciclos de ventas más cortos y tasas de conversión más altas.

Todo comienza con la incorporación

¿Cuál es una forma clave para que los proveedores de plataformas aumenten el éxito de los clientes? Bueno, para las plataformas, herramientas y proveedores de servicios, significa que realmente necesitan enfocarse en la incorporación. Incorporar clientes a su plataforma significa ponerlos al día con sus servicios para que puedan usar sus herramientas como profesionales.

También significa enseñar a sus usuarios cómo usar sus API para que puedan crear sus propias soluciones en aplicaciones. Un buen proceso de incorporación debe ser transparente y fluido. Los desarrolladores no quieren poner en producción su código "no probado". Para crear estas integraciones de forma eficaz, los desarrolladores necesitan un entorno de desarrollo seguro para probar y familiarizarse con su producto: un entorno de espacio aislado en el que puedan poner código no probado y probarlo antes de que entre en producción.

Desarrolle entornos sandbox de bajo costo para la incorporación de clientes

Si está en el negocio de vender API, la clave de las ventas es una forma eficaz y convincente de demostrar valor a sus clientes. Los entornos sandbox de desarrollo son ideales para esto, pero ¿cuáles son los requisitos para el éxito?

  • Fornido
  • Bien documentada
  • Fácilmente disponibles
  • Seguro

Fornido

Sus clientes no quieren ver errores inesperados, comportamientos inconsistentes o poco realistas. La expectativa es que su entorno sandbox se someta a las mismas pruebas rigurosas que su entorno de producción y control de calidad.

Bien documentada

Las API no son simples y los desarrolladores deben ponerse al día rápidamente para familiarizarse con su producto. Una API y un entorno sandbox bien documentados son fundamentales. Swagger y OpenAPI se han vuelto necesarios en términos de documentar y definir API y servicios. Igualmente importante es validar que los comportamientos de esas API se adhieran al esquema definido en las definiciones publicadas.

Fácilmente disponibles

Sus clientes están ansiosos por comenzar, y no tener acceso a su producto recién comprado es un obstáculo importante para el desarrollo y el trabajo de prueba de su cliente. Cualquier cantidad de tiempo de inactividad puede contribuir a una experiencia negativa.

Seguro

En el mundo del cumplimiento de PCI DSS y GDPR, la seguridad puede significar muchas cosas diferentes, pero en el contexto de las cajas de arena API, los datos de prueba en lugar de los datos reales del cliente deben usarse exclusivamente. Una caja de arena nunca debería tener acceso a los datos del cliente y, en general, las aplicaciones deberían estar suficientemente aisladas unas de otras.

Nuevamente, una buena caja de arena es crucial para la satisfacción del cliente. Hay una razón por la que hay Premios DevPortal. Las organizaciones que ponen mucho esfuerzo en una buena experiencia con los productos API obtienen reconocimiento.

Por qué los entornos sandbox de bajo costo son difíciles

Las cajas de arena son útiles pero hay una trampa. No puede simplemente configurar un montón de entornos sandbox y esperar que funcione. No es tan simple. Las API no hacen nada por sí mismas y requieren una orquestación que se integre con múltiples servicios internos y externos y sistemas backend y proporcione datos.

Configurar un entorno de zona de pruebas para una única API significa mantener todo el entorno, no solo un servicio, y esto puede ser difícil.

4 desafíos clave de los entornos sandbox de bajo costo

Hay cuatro desafíos clave para la creación de entornos sandbox de desarrollo que se asignan convenientemente a los requisitos de sandbox anteriores: los ABCD de los entornos sandbox:

  • Disponibilidad
  • Comportamiento
  • Cost
  • Datos

Disponibilidad

En pocas palabras, un entorno de sandbox debe ser estable para estar disponible y brindar una experiencia positiva al cliente. Las organizaciones ya luchan con su propio entorno de control de calidad. Mantener y ofrecer un tiempo de actividad del 100 % no es realista y el tiempo de inactividad conduce a una mala experiencia del usuario.

Comportamiento

Un entorno de caja de arena debe ser una representación fiel del sistema real. Inicialmente, las respuestas estáticas son buenas para solicitudes simples, pero las operaciones complejas requieren algún cambio de estado y lógica dinámica. ¿Qué sucede cuando un cliente desea realizar una prueba de rendimiento o una ruta negativa? Los escenarios de prueba complicados pueden ser difíciles de simular en un sistema complejo.

Cost

Mantener un entorno de prueba no es gratuito, ni las dependencias externas. Cuantos más usuarios, más escalarán esos costos. Comprender esos costos y comprender el uso se vuelve crucial para determinar el modelo de precios o de devolución de cargo que quizás desee implementar para sus usuarios finales.

Datos

Los datos de prueba en un entorno de prueba se parecen mucho a una máquina contadora de monedas. Una máquina de monedas toma sus monedas y las cuenta. Devuelve una cierta cantidad de efectivo, pero si varias personas están usando la máquina al mismo tiempo, nadie sabe cuál es el efectivo. Lo mismo sucede con los datos de prueba compartidos en entornos compartidos. Una vez que se consumen los datos, no se pueden usar para otras pruebas a menos que se reviertan los cambios de alguna manera, lo cual es complejo y requiere mucho tiempo.

Estos son desafíos que vemos aquí que reflejan lo que vemos en muchas organizaciones que también buscan mejorar sus prácticas de pruebas y automatización de pruebas. Y, francamente, la solución es bastante similar.

La virtualización de servicios marca las casillas necesarias

La virtualización de servicios es un método para emular el comportamiento de componentes específicos (virtualizar estas dependencias) en aplicaciones heterogéneas basadas en componentes, como:

  • Aplicaciones impulsadas por API
  • Aplicaciones basadas en la nube
  • Arquitecturas orientadas a servicios

Es una solución poderosa cuando se trata de simulación de API, ya que estabiliza los entornos de prueba y permite un desarrollo ágil y rápido. La virtualización de servicios de energía aporta a las pruebas de API y SOA lo convierte en una buena opción para servidores sandbox de bajo costo.

La virtualización proporciona la capacidad:

  • Cree entornos complejos bajo demanda.
  • Cree servicios realistas con un comportamiento de servicio individual controlado.
  • Realice un seguimiento del uso en todos sus entornos sandbox.
  • Cree y manipule datos para cada API única y para cada usuario individual.

Como puede ver, la virtualización de servicios realmente cumple con los requisitos.

Gráfico que muestra las casillas de verificación de virtualización de servicios
Figura 1: Casillas de verificación de virtualización de servicios para entornos de espacio aislado de bajo costo.

La virtualización de servicios es el punto ideal para los entornos de espacio aislado

En los compromisos que Parasoft ha hecho, hemos observado una regla del 80:20. Algunos entornos solo requieren respuestas estáticas simples a las llamadas API, por lo que las simulaciones simples son suficientes. Las puertas de enlace de API modernas tienen muy buenas formas de almacenar estas respuestas predefinidas, como cuando las simulaciones están integradas. Si eso es realmente todo lo que se necesita, entonces la virtualización de servicios podría ser excesiva.

En el otro extremo del espectro, el entorno debe ser muy realista. Las llamadas a la API requieren datos reales o actualizaciones reales de los sistemas backend. Surge la pregunta de si es rentable replicar tanto del sistema real como servidores virtuales. En estos casos, puede ser mejor utilizar el sistema real o un clon.

Sin embargo, en aproximadamente el 80% de los casos, los requisitos se encuentran entre estos extremos. La virtualización de servicios es suficiente para crear simulaciones realistas para escenarios de prueba y validación.

Gráfico que muestra un 10% de respuestas estáticas, un 80% de pruebas / validaciones realistas de virtualización de servicios y un 10% de flujos de trabajo que requieren sistemas backend reales
Figura 2: La virtualización de servicios se adapta a la mayoría de las necesidades de los entornos sandbox de bajo costo.

¿Cómo utilizan los clientes sus entornos sandbox?

El objetivo fundamental de una caja de arena es validar API y servicios, generalmente productos de terceros, antes de integrarse en su sistema de producción. Sin embargo, hay una escala de madurez de uso que vemos en las prácticas de creciente sofisticación con la ayuda de herramientas y virtualización de servicios.

  • Administración básica del sistema para verificar que los servicios se estén ejecutando para detectar cualquier excepción que surja y garantizar que el servidor tenga suficiente capacidad.
  • Validación para garantizar que se envíen los mensajes correctos y se respeten los flujos de trabajo correctos.
  • Certificación de socios B2B dentro de su entorno sandbox y eventual monetización.
  • Análisis e informes para la monetización de la facturación basada en el uso.

Virtualización de Parasoft proporciona soporte para estos casos de uso junto con la supervisión, el análisis y la generación de informes necesarios para un uso de sandbox más sofisticado.

Captura de pantalla del análisis y la generación de informes de uso de la zona de pruebas de Parasoft Virtualize
Figura 3: Análisis e informes de uso de la zona de pruebas proporcionados por Parasoft Virtualize.

Resumen

Un sandbox de API permite una experiencia de integración fluida para API y productos de servicio con el objetivo de mejorar el éxito del cliente. La virtualización de servicios reduce la complejidad, el costo y el riesgo de los entornos sandbox de API. Los entornos sandbox necesitan servicios casi reales y Parasoft Virtualize ofrece un rico conjunto de funciones para replicar este comportamiento de manera rápida y confiable.

Los entornos sandbox deben ser rentables y la virtualización de servicios ofrece la solución ideal para crear un entorno realista. Con eso en mente, Parasoft Virtualize proporciona escalabilidad y seguridad a los entornos sandbox de API y ofrece una variedad de modelos de implementación y un enfoque modular para la virtualización de servicios y la gestión de datos.

A medida que aumenta su sofisticación en el desarrollo de entornos aislados, la virtualización de servicios está ahí para escalar con usted y permitir el siguiente nivel de madurez.

Vea cómo Parasoft Virtualize reduce la complejidad, el costo y el riesgo de los entornos limitados de API.

 

Publicación relacionada + Recursos