Cette page explique comment utiliser un workflow CI/CD dans Looker une fois qu'il a été installé et configuré.
Ces instructions utilisent un système à trois niveaux comprenant le développement, le contrôle qualité et la production. Toutefois, vous pouvez appliquer les mêmes principes à un système à deux ou quatre niveaux.
Ces instructions supposent également que vous utilisez GitHub comme fournisseur Git. Vous pouvez utiliser d'autres fournisseurs Git pour créer un workflow CI/CD. Toutefois, vous devez posséder l'expertise nécessaire pour modifier ces instructions pour votre fournisseur.
Présentation du workflow
Les développeurs LookML commencent par écrire du code dans leur branche de développement, qui est généralement appelée dev-my-user-ydnv
, testent leurs modifications avec Spectacles et commettent leur code. Enfin, il ouvre une demande d'extraction pour fusionner son code avec la branche main
.
Lorsque la demande d'extraction est ouverte, le développeur est redirigé vers GitHub. Le développeur doit rédiger un titre de demande d'extraction pertinent en utilisant le style de commit conventionnel et ajouter un commentaire à la description qui sera inclus dans le journal des modifications. Les résultats des tests des Spectacles doivent être ajoutés en tant que commentaires à la demande de publication.
Le développeur doit ensuite sélectionner un réviseur dans GitHub. L'examinateur recevra une notification et pourra ajouter son avis à la demande de publication. Si l'examinateur approuve la modification, la demande d'extraction est fusionnée avec la branche main
. Un WebHook est appelé et l'environnement de développement voit maintenant le changement.
L'automatisation Release Please s'exécute automatiquement et ouvre une deuxième demande de publication pour créer une version taguée. Si une demande d'extraction est déjà ouverte à cette fin, Release Please la met à jour. La demande de publication est associée à un numéro de version, ainsi qu'à un journal des modifications qui inclut les titres et les descriptions des modifications incluses.
Lorsque la demande de publication générée est approuvée et fusionnée, un nouveau tag de version est généré et le journal des modifications est fusionné avec la branche main
. Les instances de test et de production de Looker peuvent sélectionner cette version à l'aide du mode de déploiement avancé.
Bonnes pratiques pour numéroter les versions et nommer les commits
Vous pouvez nommer et numéroter les versions et les balises associées de la manière qui vous convient le mieux dans votre environnement. Cependant, la gestion sémantique des versions est utilisée ici et est vivement recommandée, car elle fonctionne bien avec le plug-in Release Please.
Dans la gestion sémantique des versions, la version se compose de trois nombres séparés par des points: MAJOR.MINOR.PATCH
PATCH
est incrémenté chaque fois qu'une version corrige un bug.MINOR
est incrémenté etPATCH
est réinitialisé à zéro chaque fois que la version ajoute ou affine une fonctionnalité tout en étant rétrocompatible.MAJOR
est incrémenté, etMINOR
etPATCH
sont définis sur zéro lorsqu'une fonctionnalité non rétrocompatible est ajoutée.
Les commits conventionnels sont un système de dénomination des commits en fonction de leur impact sur les utilisateurs finaux. Bien que cela ne soit pas obligatoire, l'utilisation d'un nom de commit conventionnel est également utile pour le plug-in Release Please.
Dans la dénomination conventionnelle des commits, chaque message de commit est précédé d'un indicateur de la portée du changement:
- Une correction de bug est indiquée par
fix:
, commefix: set proper currency symbol on sale_amt format
. - Une nouvelle fonctionnalité est indiquée par
feat:
, commefeat: added explore for sales by territory
. - Une fonctionnalité avec une modification radicale est indiquée par
feat!:
, commefeat!: rewrote sales explore to use the new calendar view
. - Lorsque les documents sont mis à jour, mais que le code LookML n'est pas modifié, le message de commit commence par
doc:
.
Si les commits conventionnels sont utilisés de manière cohérente, il est généralement facile de déterminer le numéro sémantique à utiliser ensuite. Si le journal des commits ne contient que des commits fix:
et doc:
, PATCH
doit être incrémenté. Si un commit feat:
est effectué, MINOR
doit être incrémenté. Si un feat!:
est présent, MAJOR
doit être incrémenté. Le plug-in Release Please peut même générer un fichier CHANGELOG et ajouter automatiquement un tag à la version.
Utiliser le mode Déploiement avancé
Une fois les modifications apportées et envoyées en tant que PR sur l'instance de développement, le plug-in Release Please les tague avec un tag de version tel que v1.2.3
. Le mode de déploiement avancé de Looker rend ensuite ces versions disponibles dans l'interface utilisateur de Looker pour les instances de contrôle qualité et de production.
Pour déployer une modification, sélectionnez Deployment Manager dans l'IDE Looker:
Cliquez sur le lien Select Commit (Sélectionner le commit) en haut à droite du Gestionnaire de déploiement. Sélectionnez ensuite le menu à trois points associé à la balise que vous souhaitez déployer, puis choisissez Déployer dans l'environnement:
Vous n'avez pas besoin de taguer à nouveau le déploiement. Choisissez donc Déployer sans taguer, puis appuyez sur le bouton Déployer dans l'environnement:
Enfin, effectuez le déploiement en production à l'aide de Deployment Manager.
Utiliser Spectacles
Chaque développeur peut utiliser Spectacles pour vérifier ses modifications lorsqu'elles se trouvent encore dans sa branche de développement. Spectacles propose quatre validateurs différents:
Lorsqu'un développeur soumet une demande de tirage, il est recommandé d'exécuter ces tests et de copier les résultats dans un commentaire de la demande de tirage.
Outil de validation SQL
L'outil de validation SQL teste chaque exploration pour s'assurer que tous les champs définis dans les vues LookML correspondent à des colonnes SQL réelles ou à des expressions SQL valides dans la base de données. Le validateur SQL est appelé comme indiqué ci-dessous:
$ spectacles sql --config-file config-dev.yaml \
--project PROJECT_NAME \
--explores MODEL_NAME/EXPLORE_NAME \
--branch DEV_BRANCH_NAME
Exemple :
$ spectacles sql --config-file config-dev.yaml \
--project thelook_cicd \
--explores thelook_cicd/users \
--branch dev-my-user-ydnv
Connected to Looker version 23.18.60 using Looker API 4.0
=================== Testing 1/1 explores [concurrency = 10] ===================
✓ thelook_cicd.users passed
Completed SQL validation in 1 minute and 7 seconds.
Programme de validation de LookML
L'outil de validation LookML garantit que les modifications LookML sont valides et ne comportent aucune erreur de syntaxe. Il est appelé comme indiqué ci-dessous:
$ spectacles lookml --config-file config-dev.yaml \
--project PROJECT_NAME \
--branch DEV_BRANCH_NAME
Exemple :
$ spectacles lookml --config-file config-dev.yaml \
--project thelook_cicd \
--branch dev-my-user-ydnv
Connected to Looker version 23.18.60 using Looker API 4.0
============= Validating LookML in project thelook_cicd [warning] ==============
✗ thelook_cicd/business_pulse.dashboard.lookml failed
✗ thelook_cicd/thelook_cicd.model.lkml failed
================ thelook_cicd/business_pulse.dashboard.lookml:28 ===============
[Error] Unknown field "users.state" in explore "users" for field_filter.
LookML: https://gcpl2318.cloud.looker.com/projects/thelook_cicd/files/business_pulse.dashboard.lookml?line=28
================ thelook_cicd/business_pulse.dashboard.lookml:36 ===============
[Warning] Unknown field "users.state" (for explore "orders" in model
"thelook_cicd") referenced in dashboard element.
LookML: https://gcpl2318.cloud.looker.com/projects/thelook_cicd/files/business_pulse.dashboard.lookml?line=36
[Additional errors snipped]
Completed validation in 6 seconds.
Validation de contenu
L'outil de validation du contenu vérifie que tout contenu enregistré, comme les looks et les tableaux de bord définis par l'utilisateur, continue de fonctionner après les modifications. Pour accélérer l'exécution de la tâche et fournir des résultats gérables, la validation n'est effectuée que pour le contenu basé sur les explorations que vous spécifiez. Le vérificateur de contenu est appelé comme suit:
$ spectacles content --config-file config-dev.yaml \
--project PROJECT_NAME \
--explores MODEL_NAME/EXPLORE_NAME \
--branch DEV_BRANCH_NAME
Exemple :
$ spectacles content --config-file config-dev.yaml \
--project thelook_cicd \
--explores thelook_cicd/users \
--branch dev-my-user-ydnv
Connected to Looker version 23.18.60 using Looker API 4.0
Building LookML project hierarchy for project 'thelook_cicd' @ dev-my-user-ydnv
==================== Validating content based on 5 explores ====================
✗ thelook_cicd.users failed
================= test dashboard for spectacles [TheLook_CICD] =================
Tile 'test dashboard for spectacles' failed validation.
Error in thelook_cicd/users: Unknown field "users.state".
Dashboard: https://gcpl2318.cloud.looker.com/dashboards/223
========================= Business Pulse [TheLook_CICD] ========================
Filter 'State / Region' failed validation.
Error in thelook_cicd/users: Unknown field "users.state".
Dashboard: https://gcpl2318.cloud.looker.com/dashboards/190
Completed content validation in 27 seconds.
Validation d'assertion
La validation d'assertions teste les assertions de données que vous avez ajoutées à votre LookML pour vous assurer que les données sont lues correctement. Par exemple, un test de données dans votre LookML peut se présenter comme suit:
test: historic_revenue_is_accurate {
explore_source: orders {
column: total_revenue { field: orders.total_revenue }
filters: [orders.created_date: "2019"]
}
assert: revenue_is_expected_value {
expression: ${orders.total_revenue} = 626000 ;;
}
}
La validation d'assertion est appelée comme indiqué ci-dessous:
$ spectacles assert --config-file config-dev.yaml \
--project PROJECT_NAME \
--explores MODEL_NAME/EXPLORE_NAME \
--branch DEV_BRANCH_NAME
Exemple :
$ spectacles assert --config-file config-dev.yaml \
--project thelook_cicd \
--explores thelook_cicd/users \
--branch dev-my-user-ydnv
Connected to Looker version 23.18.60 using Looker API 4.0
Building LookML project hierarchy for project 'thelook_cicd' @ dev-my-user-ydnv
==================== Running data tests based on 1 explore =====================
✗ thelook_cicd.users failed
================ thelook_cicd/users/california_users_is_accurate ===============
Unknown filter field "users.state" in lookml test "california_users_is_accurate"
declaration.
LookML: https://gcpl2318.cloud.looker.com/projects/thelook_cicd/files/thelook_cicd.model.lkml?line=55
================ thelook_cicd/users/california_users_is_accurate ===============
Invalid filter: users.state
LookML: https://gcpl2318.cloud.looker.com/projects/thelook_cicd/files/thelook_cicd.model.lkml?line=55
================ thelook_cicd/users/california_users_is_accurate ===============
Assertion "count_is_expected_value" failed: expression evaluated to "No".
LookML: https://gcpl2318.cloud.looker.com/projects/thelook_cicd/files/thelook_cicd.model.lkml?line=55
Completed data test validation in 14 seconds.
Stabilité des associations pour les looks et les tableaux de bord
Par défaut, les présentations et les tableaux de bord sont associés à des ID numériques croissants qui sont utilisés dans l'URL de la présentation ou du tableau de bord. Toutefois, il n'existe aucun moyen de les synchroniser entre les systèmes. Par conséquent, l'URL d'un tableau de bord spécifique en cours de développement ne renverra pas vers le même tableau de bord en phase de contrôle qualité ou de production.
Pour les UDD, vous pouvez utiliser un slug au lieu d'un ID dans l'URL. Il s'agit d'un ensemble de caractères semi-aléatoires plutôt que d'un nombre. Le slug peut être défini lors de l'importation afin qu'une URL similaire puisse pointer vers le même UDD en développement, en contrôle qualité et en production. Il est recommandé d'utiliser des slugs au lieu d'ID, en particulier lorsque vous cliquez sur une UDD à partir d'une recherche ou d'une autre UDD.
Vous pouvez trouver le slug en inspectant la sortie de gzr dashboard cat
. Le slug peut être utilisé dans l'URL du tableau de bord à la place de l'ID numérique.
Migrer le contenu utilisateur avec Gazer
Il est souvent utile de copier des contenus tels que des looks et des tableaux de bord entre les environnements de développement, de test et de production. Vous pouvez créer du contenu qui présente les nouveaux ajouts LookML ou vous assurer que le contenu enregistré fonctionne toujours correctement après les modifications apportées à LookML. Dans ce cas, vous pouvez utiliser Gazer pour copier du contenu entre des instances.
Tableaux de bord LookML
Les tableaux de bord LookML sont synchronisés entre les instances lors du workflow CI/CD LookML standard. Toutefois, si des UDD sont synchronisées avec des tableaux de bord LookML, elles peuvent être mises à jour avec Gazer à l'aide de la commande suivante:
gzr dashboard sync_lookml DASHBOARD_ID --host TARGET_SYSTEM_URL
Tableaux de bord définis par l'utilisateur
Les tableaux de bord définis par l'utilisateur peuvent être migrés avec Gazer en référençant l'ID du tableau de bord et l'URL de l'instance Looker dans laquelle il se trouve. Gazer enregistre la configuration du tableau de bord dans un fichier JSON, qui est ensuite importé dans l'instance Looker cible.
La commande permettant d'extraire la configuration UDD est la suivante:
gzr dashboard cat DASHBOARD_ID --host TARGET_SYSTEM_URL --dir .
Un fichier nommé Dashboard_DASHBOARD_ID_DASHBOARD_NAME.json
contenant la configuration du tableau de bord est alors généré.
Vous pouvez importer le fichier UDD dans le système cible à l'aide de la commande suivante:
gzr dashboard import Dashboard_DASHBOARD_ID_DASHBOARD_NAME.json FOLDER_ID \
--host TARGET_SYSTEM_URL
Looks
La migration des looks fonctionne de manière très similaire à la migration des fiches produit. Commencez par utiliser Gazer pour enregistrer la configuration du look dans un fichier JSON:
gzr look cat LOOK_ID --host SOURCE_SYSTEM_URL --dir .
Importez ensuite la vue dans l'instance cible:
gzr look import Look_LOOK_ID_LOOK_NAME.json FOLDER_ID \
--host TARGET_SYSTEM_URL