Heim >Backend-Entwicklung >Golang >Testen Sie ein lokales Go-Modul, das mit der Anweisung „replace' importiert wurde, und verwenden Sie das Vendor-Verzeichnis im Home-Ordner
In diesem Artikel stellt der PHP-Editor Youzi vor, wie man mit dem Ersetzungsbefehl das Go-Modul lokal importiert und das Lieferantenverzeichnis im Hauptordner verwendet. Ersetzungsanweisungen sind eine leistungsstarke Funktion in der Go-Sprache, die es uns ermöglicht, lokale Module während des Entwicklungsprozesses flexibler einzuführen und die Wartbarkeit und Wiederverwendbarkeit des Codes zu verbessern. Durch die Anleitung dieses Artikels glaube ich, dass jeder diese Technik leicht beherrschen und die Go-Sprache effizienter entwickeln kann. Schauen wir uns als Nächstes die konkreten Schritte an!
myexporter ist mein lokales Modul und ich importiere es mit „replace“ in das Hauptmodul. Ich möchte Tests in myexporter unter Verwendung des Vendor-Ordners im Stammverzeichnis des Hauptprojekts ausführen.
Meine Projektverzeichnisstruktur ist so
bitbucket.com |__agent |__exporter | |__myexporter | |__factory.go | factory_test.go | go.mod |__runner | |__main.go | main_test.go |__vendor | |__bitbucket.com/agent/exporter/myexporter | |__factory.go |__go.mod
myexporter go.mod-Datei
module bitbucket.com/agent/exporter/myexporter
agent go.mod-Datei hat
module bitbucket.com/agent require ( bitbucket.com/agent/exporter/myexporter ) replace bitbucket.com/agent/exporter/myexporter => ./exporter/myexporter
Meine Frage ist
Der Build hat keinen Zugriff auf das Go-Paket, es hängt vom Herstellerordner ab, und das Gleiche gilt für die Tests. Ich möchte nicht, dass mehrere Kopien von Abhängigkeiten in einem anderen Herstellerordner in myexporter vorhanden sind. Gibt es eine Möglichkeit, Tests innerhalb von myexporter über den Ordner „agent/vendor“ auszuführen?
Gibt es eine Möglichkeit, Tests in MyExporter mithilfe des Ordners „agent/vendor“ auszuführen?
Nein.
Sie müssen testen, wo sich mein Exporter befindet. Nach der Bereitstellung wird nur der eigentliche Code bereitgestellt.
Die einzige Möglichkeit besteht darin, Module zu kombinieren.
Im Grunde läuft es darauf hinaus: Wenn Sie die beiden Module irgendwie parallel/konsistent testen müssen, handelt es sich nicht wirklich um zwei verschiedene Module mit unterschiedlichen Lebenszyklen. Wenn es sich um separate Dinge mit unterschiedlichen Lebenszyklen handeln würde, könnten Sie das erste testen, sicherstellen, dass es funktioniert, und es dem zweiten zur Verfügung stellen. Testen Sie dann den zweiten Test, einschließlich der Verwendung des ersten, aber führen Sie den ersten Test nicht aus, da er nicht mehr benötigt wird.
Das obige ist der detaillierte Inhalt vonTesten Sie ein lokales Go-Modul, das mit der Anweisung „replace' importiert wurde, und verwenden Sie das Vendor-Verzeichnis im Home-Ordner. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!