Skip to content
msinn edited this page Oct 31, 2022 · 87 revisions

Release Management

Auf dieser Seite werden die notwendigen Schritte zur Erstellung eines neuen Releases von SmartHomeNG beschrieben. Diese Schritte setzen auf dem Git Workflow Git-flow auf.

Bei einem Release sind die folgenden Schritte durchzuführen. Es sind grundsätzlich 3 Releasetypen möglich (Komplett Release, CORE Release und Plugins Release). Abhängig davon ist einer der beiden ersten Schritte (oder beide) auszuführen, gefolgt von den 3 weiteren Schritten.

Die Vergabeweise für Versionsnummern ist unter Versionsnummern beschrieben.

Git Workflow für das Release Management

Ein Workflow zum erstellen eines Releases ist auf der Seite Git-workflow(s)-für-SmartHomeNG ausführlich beschrieben. Dieser Workflow wurde bis zum Release 1.6.1 genutzt.

Der Workflow kann sowohl mit dem Kommandozeilen Tool git, als auch mit dem graphischen Client SoureTree durchgeführt werden. Eventuell ich es auch möglich andere graphische Clients hierfür zu nutzen. Das wurde jedoch nicht getestet.

Mit Release 1.7 kam ein vereinfachter Workflow zum Einsatz, der imp folgenden beschrieben ist. Dieser Workflow verzichtet auf einen extra anzulegenden Release Branch. Dieser Workflow ist im folgenden beschrieben.

Release Dokumentation vorbereiten

  • Release Notes für die Anwender Dokumentation schreiben/komplettieren (Text: Deutsch, Listen: Englisch)
  • Bemerkungs-Block "Arbeitsstand" und Blöcke mit '...' entfernen
  • Release Datum in den Release Notes setzen

CORE Release von SmartHomeNG erzeugen

  • Core repository (develop): In bin/shngversion.py Version auf die Release-Version & branch auf 'master' setzen:

    # Update auf 1.9 wg. Release
    
    shNG_version = '1.9'
    shNG_branch = 'master'
    
    • committen & pushen
      • Message: "Set repo version to 1.9.0-master"
  • master branch auschecken

    • Menü Git/Branches... -> (local Branches) origin/master -> checkout
  • develop branch mergen

    • Git/Branches -> (local) origin/develop - > merge develop into master
    • pushen
  • Optional:

    • eventuell Module und Libs entfernen, die noch nicht "Production-Ready" sind und nicht mit in das Release kommen sollen
    • committen & pushen
  • develop branch auschecken

  • Core repository (develop): In bin/shngversion.py Version auf 'nach Release' Version & branch auf 'develop' setzen:

    # Update auf 1.9 wg. Release
    # Update auf 1.9.0.1 wg. Kennzeichnung des Stands als "nach dem v1.9 Release"
    
    shNG_version = '1.9.0.1'
    shNG_branch = 'develop'
    
  • committen & pushen

    • Message: "Set repo version to post 1.9.0 release"

Damit ist das Core Release erfolgt und anschließend kann im develop Branch des Core bereits weiterentwickelt werden!

Plugins Release von SmartHomeNG erzeugen

  • Plugins repository (develop): In __init__.py Version auf die Release-Version & branch auf 'master' setzen:

      def plugin_release():
          return '1.9'
    
      def plugin_branch():
          return 'master'
    
  • Commiten (& pushen)

    • Message: "Set repo version to 1.9.0-master"
  • master branch auschecken

    • PyCharm
      • master auschecken:
        • Menü Git/Branches... -> (local Branches) origin/master -> checkout
  • develop branch mergen

    • PyCharm
      • Git/Branches -> (local) origin/develop - > merge develop into master
      • pushen
      • Optional:
        • eventuell Plugins entfernen, die noch nicht "Production- Ready" sind und nicht mit in das Release kommen sollen
        • committen & pushen
  • develop branch auschecken

    • PyCharm
      • develop auschecken:
        • Menu Git/Branches... -> (local) origin/develop -> checkout
  • Plugins repository (develop): In __init__.py Version auf 'nach Release' Version & branch auf 'develop' setzen:

      def plugin_release():
          return '1.9.0.1'
    
      def plugin_branch():
          return 'develop'
    
  • committen & pushen

    • Message: "Set repo version to post 1.9.0 release"

Damit ist das Plugin Release erfolgt und anschließend kann im develop Branch der Plugins bereits weiterentwickelt werden!

Neue Version der Dokumentation bauen

NEU: Seit v1.9.3 wird die Dokumentation automatisch beim Commit der Änderungen aus dem develop in den master branch neu gebaut. Die Doku steht dann unter docs.smarthomeng.de zur Verfügung.

Github Release/Tag erzeugen

  • Release/Tag für den Core
  • Release/Tag für die Plugins

Release Kommunikation

  • Blog:
    • Release Notes für das Blog (Verweis auf Anwender Doku) erstellen und mit Datum versehen (Bild + Kategorien setzen)
    • Vorletzte Release Notes: "Wichtig" entfernen
    • Blog Artikel veröffentlichen/freischalten
  • Kurzen Artikel für das Forum mit Hinweisen zum Update Prozess und Verweis auf die Release Notes erstellen
    • Artikel im Forum veröffentlichen (und "pinnen")
  • Release Info auf gitter posten
  • Im github Wiki in der Sidebar einen Link auf die Release Notes aus der Anwender Doku hinzufügen