


Simulieren Sie Dienste von Drittanbietern in application-go + BDD-Java
Was Ihnen der PHP-Editor Zimo heute vorstellen wird, ist die Methode zur Simulation von Drittanbieterdiensten in application-go + BDD-java. Während der Softwareentwicklung müssen wir häufig mit Diensten Dritter interagieren, während der Testphase haben wir jedoch möglicherweise keinen direkten Zugriff auf diese Dienste. Um dieses Problem zu lösen, können wir application-go und BDD-java verwenden, um das Verhalten von Drittanbieterdiensten zu simulieren und so effektivere Tests zu ermöglichen. Schauen wir uns als Nächstes die spezifische Implementierungsmethode an!
Frageninhalt
Ich habe vor kurzem mit der Recherche zu BDD begonnen (mit Gherkin + Restassured). Ich muss die Wartung durch Dritte simulieren. Das Folgende ist mein Anwendungsfall.
- Service A ruft Service B intern auf
- Die App befindet sich in goLang.
- BDD verwendet die Java-Sprache.
Bei uns läuft eine CI-Pipeline, die das RPM generiert und das RPM in der virtuellen Maschine bereitstellt. Auf dieser VM führen wir BDD aus (Derzeit werden Service-A und Service-B auf derselben VM bereitgestellt)
Gibt es eine Möglichkeit, Service-B zu verspotten, sodass ich mich nicht auf Service-B verlassen muss? Wenn ja, was ist hier der beste Ansatz?
Habe goLang httptest ausprobiert, um den Dienst auf Unit-Test-Ebene zu simulieren. Aber wie simuliert man nach dem Erstellen von RPM in der Pipeline mithilfe von BDD?
Vielen Dank
Problemumgehung
Wenn Ihr Dienst A Dienst B intern und nicht über das Web oder RPC aufruft, können Sie die Abhängigkeitsinjektion verwenden, um eine „gefälschte“ Version von Dienst B einzuschleusen. (Beachten Sie, dass es sich dabei nicht unbedingt um Abhängigkeitsinjektions-Frameworks handelt; konstruktorbasierte und eigenschaftsbasierte Injektion sind ebenfalls gültig.) Wenn Dienst B keine Schnittstelle hat, extrahieren Sie eine und verwenden Sie einen Thin-Adapter, um je nach Umgebung den echten Dienst oder den gefälschten Dienst aufzurufen.
Solange die Szene nur mit der Benutzeroberfläche oder API von Service A interagiert, müssen Sie die Szene nicht ändern.
Sie müssen die Funktionsweise Ihrer Build-Pipeline ändern, sodass sie Ihren gefälschten Code anstelle Ihres echten Codes für die Bereitstellung verwendet.
Sie können dies sogar zur Laufzeit tun und von der Fälschung zur Realität wechseln, indem Sie den Adapter den entsprechenden Dienst aufrufen lassen. Der Wechsel oder die Bereitstellung kann durch Umgebungsvariablen oder Build-Parameter ausgelöst werden.
Aber bitte achten Sie darauf, Testdienste nicht in der Produktion einzusetzen!
Wenn Sie eine kontinuierliche Bereitstellung verwenden, sollte der letzte Schritt in der Build-Pipeline idealerweise die Bereitstellung und den Test der Interaktion mit dem eigentlichen Dienst sein. Wenn dies aus irgendeinem Grund Ihre einzige Arbeitsweise ist, gibt es dennoch ein paar Dinge, die Ihnen helfen könnten:
-
Sie können die von Dienst B verwendeten Daten stutzen, damit sie sich auf vorhersehbare Weise verhalten
-
Sie können Testinstanzen verwenden. Bitte wenden Sie sich an Ihren Dienstanbieter, um zu erfahren, ob er einen Dienst anbietet, der für Sie geeignet sein könnte. Ich würde vorschlagen, dass Sie dennoch überprüfen, ob die Bereitstellung des eigentlichen Dienstes erfolgreich war, vorzugsweise mithilfe einer Art automatisierter Tests, auch wenn dieser in der Produktion ausgeführt werden muss. Führen Sie einfach einen einfachen Rauchtest durch, um zu überprüfen, ob Ihr System angeschlossen ist. Beachten Sie, dass je einfacher die Bereitstellung ist, desto einfacher ist die Wiederherstellung nach Fehlern. Wenn Sie die Bereitstellung nicht schnell durchführen können, sind gründlichere Inspektionen erforderlich.
Wenn das RPM ohne irgendeine gefälschte oder Testinstanz erstellt und bereitgestellt wird und Sie die Umgebung nicht für die Verwendung einer solchen gefälschten oder Testinstanz konfigurieren können, können Sie es nicht verspotten. Die Build-Pipeline muss Teil der Bereitstellungsfälschung sein. Wenn Sie die Kontrolle über die CI-Pipeline haben, stellt dies ansonsten kein Problem dar. Wenden Sie sich an Ihr Build-Team. Sie haben möglicherweise Erfahrung oder können Sie an andere verweisen, die Ihnen helfen können. Schließlich wird großartiges BDD durch Dialoge vorangetrieben!
Das obige ist der detaillierte Inhalt vonSimulieren Sie Dienste von Drittanbietern in application-go + BDD-Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



OpenSSL bietet als Open -Source -Bibliothek, die in der sicheren Kommunikation weit verbreitet sind, Verschlüsselungsalgorithmen, Tasten und Zertifikatverwaltungsfunktionen. In seiner historischen Version sind jedoch einige Sicherheitslücken bekannt, von denen einige äußerst schädlich sind. Dieser Artikel konzentriert sich auf gemeinsame Schwachstellen und Antwortmaßnahmen für OpenSSL in Debian -Systemen. DebianopensL Bekannte Schwachstellen: OpenSSL hat mehrere schwerwiegende Schwachstellen erlebt, wie z. Ein Angreifer kann diese Sicherheitsanfälligkeit für nicht autorisierte Lesen sensibler Informationen auf dem Server verwenden, einschließlich Verschlüsselungsschlüssel usw.

In dem Artikel wird erläutert, wie das PPROF -Tool zur Analyse der GO -Leistung verwendet wird, einschließlich der Aktivierung des Profils, des Sammelns von Daten und der Identifizierung gängiger Engpässe wie CPU- und Speicherprobleme.Character Count: 159

In dem Artikel werden Schreiben von Unit -Tests in GO erörtert, die Best Practices, Spottechniken und Tools für ein effizientes Testmanagement abdecken.

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

In dem Artikel werden die Verwaltungs -Go -Modulabhängigkeiten über Go.mod erörtert, die Spezifikationen, Aktualisierungen und Konfliktlösung abdecken. Es betont Best Practices wie semantische Versioning und reguläre Updates.

Backend Learning Path: Die Erkundungsreise von Front-End zu Back-End als Back-End-Anfänger, der sich von der Front-End-Entwicklung verwandelt, Sie haben bereits die Grundlage von Nodejs, ...

In dem Artikel werden mit Tabellensteuerungstests in GO eine Methode mit einer Tabelle mit Testfällen getestet, um Funktionen mit mehreren Eingaben und Ergebnissen zu testen. Es zeigt Vorteile wie eine verbesserte Lesbarkeit, verringerte Vervielfältigung, Skalierbarkeit, Konsistenz und a
