Créer des tests Firebase Remote Config avec A/B Testing

Lorsque vous utilisez Firebase Remote Config pour déployer des paramètres pour une application disposant d'une base d'utilisateurs active, vous devez vous assurer de bien faire les choses. Les tests A/B Testing vous permettent de déterminer au mieux les éléments suivants:

  • Le meilleur moyen d'implémenter une fonctionnalité pour optimiser l'expérience utilisateur Trop souvent, les développeurs d'applications ne s'aperçoivent pas que leurs utilisateurs n'aiment pas une nouvelle fonctionnalité ou une nouvelle expérience utilisateur que lorsque la note de leur application dans la plate-forme de téléchargement d'applications baisse. Les tests A/B peuvent vous aider à déterminer si vos utilisateurs aiment les nouvelles variantes de fonctionnalités ou s'ils préfèrent l'application telle qu'elle existe. De plus, en conservant la plupart de vos utilisateurs dans un groupe de référence, vous vous assurez que la plupart de votre base d'utilisateurs peut continuer à utiliser votre application sans que son comportement ou son apparence ne changent jusqu'à la fin du test.
  • Meilleur moyen d'optimiser l'expérience utilisateur pour un objectif commercial Parfois, vous implémentez des modifications de produit pour maximiser une métrique comme les revenus ou la fidélisation. Avec les tests A/B, vous définissez votre objectif commercial, et Firebase effectue l'analyse statistique pour déterminer si une variante surpasse la référence pour l'objectif sélectionné.

Pour effectuer des tests A/B sur des variantes de fonctionnalités avec un niveau de référence, procédez comme suit :

  1. Créez votre test.
  2. Validez votre test sur un appareil de test.
  3. Gérez votre test.

Créer un test

Un test Remote Config vous permet d'évaluer plusieurs variantes sur un ou plusieurs paramètres Remote Config.

  1. Connectez-vous à la console Firebase et vérifiez que Google Analytics est activé dans votre projet afin que le test ait accès aux données Analytics.

    Si vous n'avez pas activé Google Analytics lors de la création de votre projet, vous pouvez l'activer dans l'onglet Intégrations, accessible via > Paramètres du projet dans la console Firebase.

  2. Dans la section Engage (Engagement) du menu de navigation de la console Firebase, cliquez sur A/B Testing.

  3. Cliquez sur Créer un test, puis sélectionnez Remote Config lorsque vous êtes invité à choisir le service que vous souhaitez tester.

  4. Saisissez un nom et une description facultative pour votre test, puis cliquez sur Suivant.

  5. Remplissez les champs Ciblage en commençant par choisir l'application qui utilise votre test. Vous pouvez également cibler un sous-ensemble de vos utilisateurs pour qu'ils participent à votre test. Pour ce faire, cliquez sur et, puis sélectionnez des options dans la liste suivante :

    • Version : une ou plusieurs versions de votre application
    • Numéro de build : code de version de l'application
    • Langues : une ou plusieurs langues et zones géographiques utilisées pour sélectionner les utilisateurs susceptibles d'être inclus dans le test
    • Pays/Région : un ou plusieurs pays ou régions pour sélectionner les utilisateurs à inclure dans le test
    • Audience utilisateur : audiences Analytics utilisées pour cibler les utilisateurs susceptibles d'être inclus dans le test
    • Propriété utilisateur:une ou plusieurs propriétés utilisateur Analytics permettant de sélectionner les utilisateurs pouvant être inclus dans le test.
    • Première ouverture : ciblez les utilisateurs en fonction de la première fois qu'ils ont ouvert votre application.

      Le ciblage par heure de première ouverture est disponible après avoir sélectionné une application Android ou iOS. Il est compatible avec les versions suivantes du SDK Remote Config: SDK Apple Platforms v9.0.0 et versions ultérieures, et SDK Android v21.1.1 et versions ultérieures (Firebase BoM v30.3.0 et versions ultérieures).

      Analytics doit également avoir été activé sur le client lors du premier événement d'ouverture.

  6. Définissez le Pourcentage d'utilisateurs cibles : saisissez le pourcentage de la base d'utilisateurs de votre application correspondant aux critères définis sous Utilisateurs cibles que vous souhaitez répartir de manière uniforme entre la référence et une ou plusieurs variantes de votre test. Il peut s'agir de n'importe quel pourcentage compris entre 0,01% et 100%. Les utilisateurs sont attribués de manière aléatoire à chaque test, y compris aux tests en double.

  7. Vous pouvez également définir un événement d'activation pour vous assurer que seules les données des utilisateurs qui ont déclenché un événement Analytics en premier sont comptabilisées dans votre test. Notez que tous les utilisateurs correspondant à vos paramètres de ciblage recevront des valeurs expérimentales Remote Config, mais seuls ceux qui déclenchent un événement d'activation seront inclus dans les résultats de votre test.

    Pour garantir la validité du test, assurez-vous que l'événement que vous choisissez se produit après que votre application a activé les valeurs de configuration extraites. En outre, les événements suivants ne peuvent pas être utilisés, car ils se produisent toujours avant l'activation des valeurs extraites :

    • app_install
    • app_remove
    • app_update
    • dynamic_link_first_open
  8. Pour les objectifs du test, sélectionnez la métrique principale à suivre, puis ajoutez les métriques supplémentaires que vous souhaitez suivre dans la liste. Il s'agit d'objectifs intégrés (achats, revenus, fidélisation, utilisateurs n'ayant pas subi de plantage, etc.), des événements de conversion Analytics et d'autres événements Analytics ; Lorsque vous avez terminé, cliquez sur Suivant.

  9. Dans la section Variantes, choisissez une référence et au moins une variante pour le test. Utilisez la liste Choisir ou créer pour ajouter un ou plusieurs paramètres à tester. Vous pouvez créer un paramètre qui n'a pas encore été utilisé dans la console Firebase, mais il doit exister dans votre application pour qu'il ait un effet. Vous pouvez répéter cette étape pour ajouter plusieurs paramètres à votre test.

  10. (Facultatif) Pour ajouter plusieurs variantes à votre test, cliquez sur Ajouter une variante.

  11. Modifier un ou plusieurs paramètres pour des variantes spécifiques Les paramètres inchangés sont les mêmes pour les utilisateurs non inclus dans le test.

  12. Développez Pondérations des variantes pour afficher ou modifier la pondération des variantes pour le test. Par défaut, chaque variante est pondérée de la même manière. Notez qu'une pondération inégale peut augmenter la durée de collecte des données. La pondération ne peut par ailleurs pas être modifiée une fois que le test a commencé.

  13. Cliquez sur Examiner pour enregistrer votre test.

Vous pouvez créer jusqu'à 300 tests par projet, dont 24 tests en cours, et les autres en brouillon ou terminés.

Valider votre test sur un appareil de test

Pour chaque installation Firebase, vous pouvez récupérer le jeton d'authentification d'installation qui lui est associé. Vous pouvez utiliser ce jeton pour tester des variantes d'un test spécifique sur un appareil de test sur lequel votre application est installée. Pour valider votre test sur un appareil de test, procédez comme suit :

  1. Obtenez le jeton d'authentification d'installation comme suit :

    Swift

    do {
      let result = try await Installations.installations()
        .authTokenForcingRefresh(true)
      print("Installation auth token: \(result.authToken)")
    } catch {
      print("Error fetching token: \(error)")
    }

    Objective-C

    [[FIRInstallations installations] authTokenForcingRefresh:true
                                                   completion:^(FIRInstallationsAuthTokenResult *result, NSError *error) {
      if (error != nil) {
        NSLog(@"Error fetching Installation token %@", error);
        return;
      }
      NSLog(@"Installation auth token: %@", [result authToken]);
    }];

    Java

    FirebaseInstallations.getInstance().getToken(/* forceRefresh */true)
            .addOnCompleteListener(new OnCompleteListener<InstallationTokenResult>() {
        @Override
        public void onComplete(@NonNull Task<InstallationTokenResult> task) {
            if (task.isSuccessful() && task.getResult() != null) {
                Log.d("Installations", "Installation auth token: " + task.getResult().getToken());
            } else {
                Log.e("Installations", "Unable to get Installation auth token");
            }
        }
    });

    Kotlin+KTX

    val forceRefresh = true
    FirebaseInstallations.getInstance().getToken(forceRefresh)
        .addOnCompleteListener { task ->
            if (task.isSuccessful) {
                Log.d("Installations", "Installation auth token: " + task.result?.token)
            } else {
                Log.e("Installations", "Unable to get Installation auth token")
            }
        }

    C++

    firebase::InitResult init_result;
    auto* installations_object = firebase::installations::Installations::GetInstance(
        firebase::App::GetInstance(), &init_result);
    installations_object->GetToken().OnCompletion(
        [](const firebase::Future<std::string>& future) {
          if (future.status() == kFutureStatusComplete &&
              future.error() == firebase::installations::kErrorNone) {
            printf("Installations Auth Token %s\n", future.result()->c_str());
          }
        });

    Unity

    Firebase.Installations.FirebaseInstallations.DefaultInstance.GetTokenAsync(forceRefresh: true).ContinueWith(
      task => {
        if (!(task.IsCanceled || task.IsFaulted) && task.IsCompleted) {
          UnityEngine.Debug.Log(System.String.Format("Installations token {0}", task.Result));
        }
      });
  2. Dans la barre de navigation de la console Firebase, cliquez sur Tests A/B.
  3. Cliquez sur Brouillon (et/ou En cours d'exécution pour les tests Remote Config), pointez sur votre test, cliquez sur le menu contextuel (), puis sur Gérer les appareils de test.
  4. Saisissez le jeton d'authentification d'installation d'un appareil de test, puis choisissez la variante de test à envoyer à cet appareil.
  5. Exécutez l'application et vérifiez que la variante sélectionnée est reçue sur l'appareil de test.

Pour en savoir plus sur les installations Firebase, consultez la section Gérer les installations Firebase.

Gérer votre test

Que vous créiez un test avec Remote Config, l'outil de création de notifications ou Firebase In-App Messaging, vous pouvez ensuite valider et lancer votre test, le surveiller pendant son exécution et augmenter le nombre d'utilisateurs inclus dans votre test en cours.

Une fois votre test terminé, vous pouvez noter les paramètres utilisés par la variante gagnante, puis les déployer auprès de tous les utilisateurs. Vous pouvez également exécuter un autre test.

Démarrer un test

  1. Dans la section Engage (Engagement) du menu de navigation de la console Firebase, cliquez sur A/B Testing.
  2. Cliquez sur Brouillon, puis sur le titre de votre test.
  3. Pour vérifier que votre application inclut des utilisateurs dans votre test, développez les détails de l'aperçu et recherchez un nombre supérieur à 0 % dans la section Ciblage et distribution (par exemple, 1 % des utilisateurs correspondant aux critères).
  4. Pour modifier votre test, cliquez sur Modifier.
  5. Pour lancer votre test, cliquez sur Démarrer le test. Vous pouvez effectuer jusqu'à 24 tests par projet à la fois.

Surveiller un test

Une fois qu'un test a été exécuté pendant un certain temps, vous pouvez vérifier sa progression et voir à quoi ressemblent vos résultats pour les utilisateurs qui y ont participé jusqu'à présent.

  1. Dans la section Engage (Engagement) du menu de navigation de la console Firebase, cliquez sur A/B Testing.
  2. Cliquez sur En cours, puis sur le titre de votre test ou recherchez-le. Sur cette page, vous pouvez consulter diverses statistiques observées et modélisées sur votre test en cours, y compris les suivantes :

    • Différence par rapport à la valeur de référence (%) : mesure de l'amélioration d'une métrique pour une variante donnée par rapport à la valeur de référence. Calculé en comparant la plage de valeurs de la variante à la plage de valeurs de la référence.
    • Probabilité de surpasser la référence: estimation de la probabilité qu'une variante donnée surpasse la référence pour la métrique sélectionnée.
    • observed_metric par utilisateur : d'après les résultats du test, il s'agit de la plage de valeurs prévue dans laquelle la valeur de la métrique se situera au fil du temps.
    • observed_metric total : valeur cumulée observée pour la référence ou la variante. Cette valeur permet de mesurer les performances de chaque variante d'un test, et de calculer l'Amélioration, la Plage de valeurs, la Probabilité de battre la valeur de référence et la Probabilité d'être la meilleure variante. Selon la métrique mesurée, cette colonne peut être intitulée "Durée par utilisateur", "Revenus par utilisateur", "Taux de fidélisation" ou "Taux de conversion".
  3. Une fois que votre test a été exécuté pendant un certain temps (au moins sept jours pour FCM et In-App Messaging, ou 14 jours pour Remote Config), les données de cette page indiquent la variante, le cas échéant, qui est la "leader". Certaines mesures sont accompagnées d'un graphique à barres qui présente les données dans un format visuel.

Déployer un test auprès de tous les utilisateurs

Une fois qu'un test a duré suffisamment longtemps pour disposer d'une variante "leader" (ou gagnante) pour votre métrique d'objectif, vous pouvez lancer le test auprès de 100% des utilisateurs. Cela vous permet de sélectionner une variante qui sera désormais présentée à tous les utilisateurs. Même si votre test n'a pas permis de déterminer clairement un gagnant, vous pouvez tout de même déployer une variante auprès de tous vos utilisateurs.

  1. Dans la section Engage (Engagement) du menu de navigation de la console Firebase, cliquez sur A/B Testing.
  2. Cliquez sur Terminé ou En cours, cliquez sur le test que vous souhaitez déployer auprès de tous les utilisateurs, cliquez sur le menu contextuel () et sur Déployer la variante.
  3. Déployez votre test auprès de tous les utilisateurs en procédant comme suit :

    • Pour un test qui utilise l'outil de création de notifications, utilisez la boîte de dialogue Message de déploiement pour envoyer le message aux utilisateurs ciblés restants qui ne faisaient pas partie du test.
    • Pour un test Remote Config, sélectionnez une variante afin de déterminer les valeurs de paramètre Remote Config à mettre à jour. Les critères de ciblage définis lorsque vous avez créé le test sont ajoutés en tant que nouvelle condition dans votre modèle afin que seuls les utilisateurs ciblés par le test soient concernés par le déploiement. Après avoir cliqué sur Examiner dans Remote Config pour examiner les modifications, cliquez sur Publier les modifications pour terminer le déploiement.
    • Pour un test In-App Messaging, utilisez la boîte de dialogue pour déterminer quelle variante doit être déployée en tant que campagne In-App Messaging autonome. Une fois la sélection effectuée, vous êtes redirigé vers l'écran de composition FIAM pour apporter les modifications nécessaires (le cas échéant) avant de publier le message.

Développer un test

Si vous constatez qu'un test n'attire pas suffisamment d'utilisateurs pour que A/B Testing déclare un gagnant, vous pouvez augmenter la distribution de votre test pour toucher un pourcentage plus élevé de la base d'utilisateurs de l'application.

  1. Dans la section Engage (Engagement) du menu de navigation de la console Firebase, cliquez sur A/B Testing.
  2. Sélectionnez le test en cours que vous souhaitez modifier.
  3. Dans la section Présentation du test, cliquez sur le menu contextuel (), puis sur Modifier le test en cours d'exécution.
  4. La boîte de dialogue Ciblage affiche une option permettant d'augmenter le pourcentage d'utilisateurs participant au test en cours. Sélectionnez un nombre supérieur au pourcentage actuel, puis cliquez sur Publier. Le test sera déployé auprès du pourcentage d'utilisateurs que vous avez spécifié.

Dupliquer ou arrêter un test

  1. Dans la section Engage (Engagement) du menu de navigation de la console Firebase, cliquez sur A/B Testing.
  2. Cliquez sur Terminé ou En cours d'exécution, maintenez le pointeur sur votre test, cliquez sur le menu contextuel (), puis sur Dupliquer le test ou Arrêter le test.

Ciblage par utilisateur

Vous pouvez cibler les utilisateurs à inclure dans votre test à l'aide des critères de ciblage des utilisateurs suivants.

Critère de ciblage Opérateur(s)  Valeur(s) Remarque
Version contient,
ne contient pas,
correspond exactement,
contient une expression régulière
Saisissez une valeur pour une ou plusieurs versions d'application que vous souhaitez inclure dans le test.

Lorsque vous utilisez les opérateurs contient, ne contient pas ou correspond exactement, vous pouvez fournir une liste de valeurs séparées par des virgules.

Lorsque vous utilisez l'opérateur contient une expression régulière, vous pouvez créer des expressions régulières au format RE2. Votre expression régulière peut correspondre à tout ou partie de la chaîne de version cible. Vous pouvez également utiliser les ancres ^ et $ pour faire correspondre le début, la fin ou l'intégralité d'une chaîne cible.

Audiences d'utilisateurs inclut tous les éléments,
inclut au moins un des éléments,
n'inclut pas tous les éléments,
n'inclut pas au moins un des éléments
Sélectionnez une ou plusieurs audiences Analytics pour cibler les utilisateurs susceptibles d'être inclus dans votre test. Certains tests qui ciblent des audiences Google Analytics peuvent nécessiter quelques jours pour accumuler des données, car ils sont soumis à la latence de traitement des données Analytics. Ce délai est le plus susceptible de se produire avec les nouveaux utilisateurs, qui sont généralement inscrits aux audiences éligibles 24 à 48 heures après leur création, ou pour les audiences créées récemment.

Pour Remote Config, cela signifie que même si un utilisateur est techniquement éligible à une audience, si Analytics ne l'a pas encore ajouté à l'audience lors de l'exécution de "fetchAndActivate()", il ne sera pas inclus dans le test.

Propriété utilisateur Pour le texte:
contient,
ne contient pas,
correspond exactement à,
contient l'expression régulière

Pour les nombres:
<, ≤, =, ≥, >
Une propriété utilisateur Analytics permet de sélectionner des utilisateurs pouvant être inclus dans un test, avec une plage d'options de sélection des valeurs de la propriété utilisateur.

Sur le client, vous ne pouvez définir que des valeurs de chaîne pour les propriétés utilisateur. Pour les conditions qui utilisent des opérateurs numériques, le service Remote Config convertit la valeur de la propriété utilisateur correspondante en nombre entier/float.
Lorsque vous utilisez l'opérateur contient une expression régulière, vous pouvez créer des expressions régulières au format RE2. Votre expression régulière peut correspondre à tout ou partie de la chaîne de version cible. Vous pouvez également utiliser les ancres ^ et $ pour faire correspondre le début, la fin ou l'intégralité d'une chaîne cible.
Pays/Région N/A Un ou plusieurs pays ou régions utilisés pour sélectionner les utilisateurs susceptibles d'être inclus dans le test.  
Langages N/A Une ou plusieurs langues et paramètres régionaux utilisés pour sélectionner les utilisateurs susceptibles d'être inclus dans le test.  
Première ouverture Avant
Après

Ciblez les utilisateurs en fonction de la première fois qu'ils ouvrent votre application :

  • Sélectionnez Nouveaux utilisateurs pour cibler les utilisateurs qui ouvrent votre application pour la première fois après une date et une heure ultérieures spécifiées.
  • Sélectionnez Plage temporelle pour cibler les utilisateurs qui ouvrent votre application pour la première fois dans la plage avant ou après la date et l'heure que vous spécifiez. Combinez les conditions Avant et Après pour cibler les utilisateurs au cours d'une période spécifique.

Le ciblage par première ouverture est disponible après avoir sélectionné une application Android ou iOS. Il est actuellement compatible avec les versions suivantes du SDK Remote Config : SDK Apple Platforms v9.0.0 et versions ultérieures, et SDK Android v21.1.1 et versions ultérieures (Firebase BoM v30.3.0 et versions ultérieures).

Analytics doit également avoir été activé sur le client lors du premier événement d'ouverture.

A/B Testing métriques

Lorsque vous créez votre test, vous choisissez une métrique principale, ou objectif, qui est utilisée pour déterminer la variante gagnante. Vous devez également suivre d'autres métriques pour mieux comprendre les performances de chaque variante de test et suivre les tendances importantes qui peuvent différer pour chaque variante, comme la rétention des utilisateurs, la stabilité de l'application et les revenus générés par les achats via l'application. Vous pouvez suivre jusqu'à cinq métriques qui ne sont pas des objectifs dans votre test.

Par exemple, imaginons que vous utilisiez Remote Config pour lancer deux flux de jeu différents dans votre application et que vous souhaitiez optimiser les achats via l'application et les revenus publicitaires, mais que vous souhaitiez également suivre la stabilité et la rétention des utilisateurs de chaque variante. Dans ce cas, vous pouvez envisager de choisir Estimation des revenus totaux comme métrique d'objectif, car elle inclut les revenus publicitaires et les revenus issus des achats via l'application. Ensuite, pour Autres métriques à suivre, vous pourriez ajouter les éléments suivants:

  • Pour suivre la rétention des utilisateurs au quotidien et chaque semaine, ajoutez Fidélisation (2-3 jours) et Fidélisation (4-7 jours).
  • Pour comparer la stabilité entre les deux flux de jeu, ajoutez Utilisateurs n'ayant pas subi de plantage.
  • Pour afficher des vues plus détaillées de chaque type de revenus, ajoutez Revenus issus des achats et Revenus publicitaires estimés.

Les tableaux suivants expliquent comment les métriques d'objectif et d'autres métriques sont calculées.

Statistiques "Objectif"

Métrique Description
Utilisateurs n'ayant pas subi de plantage Pourcentage d'utilisateurs n'ayant pas rencontré d'erreurs dans votre application détectées par le SDK Firebase Crashlytics pendant le test.
Revenus publicitaires estimés Revenus publicitaires estimés.
Total des revenus estimés Valeur combinée des achats et des revenus publicitaires estimés.
Revenus issus des achats Valeur combinée pour tous les événements purchase et in_app_purchase.
Fidélisation (1 jour) Nombre d'utilisateurs qui reviennent quotidiennement sur votre application.
Fidélisation (2-3 jours) Nombre d'utilisateurs qui reviennent sur votre application dans les deux à trois jours.
Fidélisation (4-7 jours) Nombre d'utilisateurs qui reviennent dans votre application sous 4 à 7 jours.
Fidélisation (8-14 jours) Nombre d'utilisateurs qui reviennent sur votre application dans les 8 à 14 jours.
Fidélisation (plus de 15 jours) Nombre d'utilisateurs qui reviennent sur votre application 15 jours ou plus après leur dernière utilisation.
first_open Événement Analytics déclenché lorsqu'un utilisateur ouvre une application pour la première fois après l'avoir installée ou réinstallée. Utilisées dans un entonnoir de conversion.

Autres métriques

Métrique Description
notification_dismiss Événement Analytics qui se déclenche lorsqu'une notification envoyée par l'outil de création de notifications est ignorée (Android uniquement).
notification_receive Événement Analytics déclenché lorsqu'une notification envoyée par le compositeur de notifications est reçue alors que l'application est exécutée en arrière-plan (Android uniquement).
os_update Événement Analytics qui suit la mise à jour du système d'exploitation de l'appareil vers une nouvelle version. Pour en savoir plus, consultez la section Événements collectés automatiquement.
screen_view Événement Analytics qui suit les écrans visionnés dans votre application. Pour en savoir plus, consultez Suivre les visionnages d'écran.
session_start Événement Analytics qui comptabilise les sessions utilisateur dans votre application. Pour en savoir plus, consultez la section Événements collectés automatiquement.

Exportation de données BigQuery

En plus d'afficher les données de test A/B Testing dans la console Firebase, vous pouvez inspecter et analyser les données de test dans BigQuery. Bien que A/B Testing ne dispose pas d'une table BigQuery distincte, les appartenances aux tests et aux variantes sont stockées dans chaque événement Google Analytics dans les tables d'événements Analytics.

Les propriétés utilisateur qui contiennent des informations sur le test sont au format userProperty.key like "firebase_exp_%" ou userProperty.key = "firebase_exp_01", où 01 correspond à l'ID de test et userProperty.value.string_value contient l'index (basé sur zéro) de la variante de test.

Vous pouvez utiliser ces propriétés utilisateur de test pour extraire les données du test. Vous pouvez ainsi découper les résultats de votre test de différentes manières et vérifier indépendamment les résultats de A/B Testing.

Pour commencer, procédez comme suit, comme décrit dans ce guide :

  1. Activez l'exportation BigQuery pour Google Analytics dans la console Firebase.
  2. Accéder aux données A/B Testing à l'aide de BigQuery
  3. Explorer des exemples de requêtes

Activer l'exportation BigQuery pour Google Analytics dans la console Firebase

Si vous disposez du forfait Spark, vous pouvez utiliser le bac à sable BigQuery pour accéder à BigQuery sans frais, sous réserve des limites du bac à sable. Pour en savoir plus, consultez la section Tarifs et bac à sable BigQuery.

Tout d'abord, assurez-vous d'exporter vos données Analytics vers BigQuery :

  1. Ouvrez l'onglet Intégrations, auquel vous pouvez accéder à l'aide de > Paramètres du projet dans la console Firebase.
  2. Si vous utilisez déjà BigQuery avec d'autres services Firebase, cliquez sur Gérer. Sinon, cliquez sur Associer.
  3. Consultez À propos de l'association de Firebase à BigQuery, puis cliquez sur Suivant.
  4. Dans la section Configurer l'intégration, activez l'option Google Analytics.
  5. Sélectionnez une région, puis choisissez les paramètres d'exportation.

  6. Cliquez sur Associer à BigQuery.

Selon la méthode choisie pour exporter les données, l'accès aux tableaux peut prendre jusqu'à une journée. Pour en savoir plus sur l'exportation des données de projet vers BigQuery, consultez Exporter les données de projet vers BigQuery.

Accéder aux données A/B Testing dans BigQuery

Avant d'interroger des données pour un test spécifique, vous devez obtenir tout ou partie des éléments suivants à utiliser dans votre requête:

  • ID du test : vous pouvez l'obtenir à partir de l'URL de la page Présentation du test. Par exemple, si votre URL se présente comme https://console.firebase.google.com/project/my_firebase_project/config/experiment/results/25, l'ID de l'expérience est 25.
  • ID de la propriété Google Analytics: il s'agit de votre ID de propriété Google Analytics à neuf chiffres. Vous pouvez le trouver dans Google Analytics. Il apparaît également dans BigQuery lorsque vous développez le nom de votre projet pour afficher le nom de votre table d'événements Google Analytics (project_name.analytics_000000000.events).
  • Date du test : pour composer une requête plus rapide et plus efficace, il est recommandé de limiter vos requêtes aux partitions de table d'événements quotidiens Google Analytics contenant vos données de test (tables identifiées par un suffixe YYYYMMDD). Par conséquent, si votre test s'est déroulé du 2 février 2024 au 2 mai 2024, vous devez spécifier un _TABLE_SUFFIX between '20240202' AND '20240502'. Pour en savoir plus, consultez Sélectionner les valeurs d'un test spécifique.
  • Noms des événements : ils correspondent généralement aux métriques d'objectif que vous avez configurées dans le test. Par exemple, des événements in_app_purchase, ad_impression ou user_retention.
.

Une fois que vous avez rassemblé les informations nécessaires pour générer votre requête :

  1. Ouvrez BigQuery dans la console Google Cloud.
  2. Sélectionnez votre projet, puis Créer une requête SQL.
  3. Ajoutez votre requête. Pour obtenir des exemples de requêtes à exécuter, consultez la section Explorer des exemples de requêtes.
  4. Cliquez sur Exécuter.

Interroger les données du test à l'aide de la requête générée automatiquement par la console Firebase

Si vous utilisez le forfait Blaze, la page Présentation du test fournit un exemple de requête qui renvoie le nom du test, les variantes, les noms des événements et le nombre d'événements pour le test que vous consultez.

Pour obtenir et exécuter la requête générée automatiquement :

  1. Dans la console Firebase, ouvrez A/B Testing, puis sélectionnez le test A/B Testing que vous souhaitez interroger pour ouvrir la présentation du test.
  2. Dans le menu "Options", sous Intégration BigQuery, sélectionnez Interroger les données du test. Cela ouvre votre projet dans BigQuery dans la console Google Cloud et fournit une requête de base que vous pouvez utiliser pour interroger vos données de test.

L'exemple suivant montre une requête générée pour un test avec trois variantes (y compris la référence) nommé "Test d'accueil hivernal". Elle renvoie le nom du test actif, le nom de la variante, l'événement unique et le nombre d'événements pour chaque événement. Notez que le générateur de requêtes ne spécifie pas le nom de votre projet dans le nom de la table, car il s'ouvre directement dans votre projet.

  /*
    This query is auto-generated by Firebase A/B Testing for your
    experiment "Winter welcome experiment".
    It demonstrates how you can get event counts for all Analytics
    events logged by each variant of this experiment's population.
  */
  SELECT
    'Winter welcome experiment' AS experimentName,
    CASE userProperty.value.string_value
      WHEN '0' THEN 'Baseline'
      WHEN '1' THEN 'Welcome message (1)'
      WHEN '2' THEN 'Welcome message (2)'
      END AS experimentVariant,
    event_name AS eventName,
    COUNT(*) AS count
  FROM
    `analytics_000000000.events_*`,
    UNNEST(user_properties) AS userProperty
  WHERE
    (_TABLE_SUFFIX BETWEEN '20240202' AND '20240502')
    AND userProperty.key = 'firebase_exp_25'
  GROUP BY
    experimentVariant, eventName

Pour obtenir d'autres exemples de requêtes, consultez la section Explorer des exemples de requêtes.

Explorer des exemples de requêtes

Les sections suivantes fournissent des exemples de requêtes que vous pouvez utiliser pour extraire les données de test A/B Testing à partir des tables d'événements Google Analytics.

Extraire les valeurs d'écart type des achats et des tests de tous les tests

Vous pouvez utiliser les données des résultats du test pour vérifier de manière indépendante les résultats Firebase A/B Testing. L'instruction SQL BigQuery suivante extrait les variantes d'expérience, le nombre d'utilisateurs uniques dans chaque variante, et somme les revenus totaux des événements in_app_purchase et ecommerce_purchase, ainsi que les écarts-types pour toutes les expériences au cours de la période spécifiée comme dates de début et de fin de l'_TABLE_SUFFIX. Vous pouvez utiliser les données que vous obtenez de cette requête avec un générateur de signification statistique pour les tests t à extrémité unique afin de vérifier que les résultats fournis par Firebase correspondent à votre propre analyse.

Pour en savoir plus sur la façon dont A/B Testing calcule l'inférence, consultez la section Interpréter les résultats des tests.

  /*
    This query returns all experiment variants, number of unique users,
    the average USD spent per user, and the standard deviation for all
    experiments within the date range specified for _TABLE_SUFFIX.
  */
  SELECT
    experimentNumber,
    experimentVariant,
    COUNT(*) AS unique_users,
    AVG(usd_value) AS usd_value_per_user,
    STDDEV(usd_value) AS std_dev
  FROM
    (
      SELECT
        userProperty.key AS experimentNumber,
        userProperty.value.string_value AS experimentVariant,
        user_pseudo_id,
        SUM(
          CASE
            WHEN event_name IN ('in_app_purchase', 'ecommerce_purchase')
              THEN event_value_in_usd
            ELSE 0
            END) AS usd_value
      FROM `PROJECT_NAME.analytics_ANALYTICS_ID.events_*`
      CROSS JOIN UNNEST(user_properties) AS userProperty
      WHERE
        userProperty.key LIKE 'firebase_exp_%'
        AND event_name IN ('in_app_purchase', 'ecommerce_purchase')
        AND (_TABLE_SUFFIX BETWEEN 'YYYYMMDD' AND 'YYYMMDD')
      GROUP BY 1, 2, 3
    )
  GROUP BY 1, 2
  ORDER BY 1, 2;

Sélectionner les valeurs d'un test spécifique

L'exemple de requête suivant montre comment obtenir des données pour un test spécifique dans BigQuery. Cet exemple de requête renvoie le nom du test, les noms des variantes (y compris la référence), les noms des événements et leur nombre.

  SELECT
    'EXPERIMENT_NAME' AS experimentName,
    CASE userProperty.value.string_value
      WHEN '0' THEN 'Baseline'
      WHEN '1' THEN 'VARIANT_1_NAME'
      WHEN '2' THEN 'VARIANT_2_NAME'
      END AS experimentVariant,
    event_name AS eventName,
    COUNT(*) AS count
  FROM
    `analytics_ANALYTICS_PROPERTY.events_*`,
    UNNEST(user_properties) AS userProperty
  WHERE
    (_TABLE_SUFFIX BETWEEN 'YYYMMDD' AND 'YYYMMDD')
    AND userProperty.key = 'firebase_exp_EXPERIMENT_NUMBER'
  GROUP BY
    experimentVariant, eventName