Testez votre intégration à l'aide d'Amazon GameLift Local - Amazon GameLift

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

Testez votre intégration à l'aide d'Amazon GameLift Local

Note

Cette rubrique traite des tests pour les jeux intégrés à la SDK version 4.x ou antérieure GameLift du serveur Amazon uniquement. Votre SDK package de serveur inclut une version compatible d'Amazon GameLift Local. Si vous utilisez la SDK version 5.x du serveur, consultez la section Configurez des tests locaux avec Amazon GameLift Anywhere pour effectuer des tests locaux avec un Amazon GameLift Anywhere flotte.

Utilisez Amazon GameLift Local pour exécuter une version limitée du GameLift service Amazon géré sur un appareil local et tester l'intégration de votre jeu par rapport à celui-ci. Cet outil est utile lors de l'exécution d'un développement itératif sur l'intégration de votre jeu. L'alternative, qui consiste à télécharger chaque nouvelle version sur Amazon GameLift et à configurer une flotte pour héberger votre jeu, peut prendre plusieurs ou plus à chaque fois.

Amazon GameLift Local vous permet de vérifier les points suivants :

  • Votre serveur de jeu est correctement intégré au serveur SDK et communique correctement avec le GameLift service Amazon pour démarrer de nouvelles sessions de jeu, accepter de nouveaux joueurs et signaler l'état de santé et l'état de santé.

  • Votre client de jeu est correctement intégré à Amazon GameLift et est capable de récupérer des informations sur les sessions de jeu existantes, de démarrer de nouvelles sessions de jeu, de rejoindre des joueurs et de se connecter à la session de jeu. AWS SDK

Amazon GameLift Local est un outil de ligne de commande qui lance une version autonome du service Amazon géré. GameLift Amazon GameLift Local fournit également un journal des événements courants concernant l'initialisation des processus du serveur, les bilans de santé, les API appels et les réponses. Amazon GameLift Local reconnaît un sous-ensemble des AWS SDK actions pour Amazon GameLift. Vous pouvez passer des appels depuis AWS CLI ou depuis le client de jeu. Toutes les API actions sont effectuées localement, comme sur le service GameLift Web Amazon.

Chaque processus serveur ne doit héberger qu'une seule session de jeu. La session de jeu est le fichier exécutable que vous utilisez pour vous connecter à Amazon GameLift Local. Lorsque la session de jeu est terminée, vous devez appeler GameLiftServerSDK::ProcessEnding puis quitter le processus. Lorsque vous testez localement avec Amazon GameLift Local, vous pouvez démarrer plusieurs processus de serveur. Chaque processus sera connecté à Amazon GameLift Local. Vous pouvez ensuite créer une session de jeu pour chaque processus du serveur. Lorsque votre session de jeu se termine, le processus de votre serveur de jeu devrait se terminer. Vous devez ensuite démarrer manuellement un autre processus serveur.

Amazon GameLift local prend en charge les services suivants APIs :

  • CreateGameSession

  • CreatePlayerSession

  • CreatePlayerSessions

  • DescribeGameSessions

  • DescribePlayerSessions

Configurer Amazon GameLift local

Amazon GameLift Local est fourni sous forme de .jar fichier exécutable fourni avec le serveur SDK. Il peut être exécuté sous Windows ou Linux et utilisé avec n'importe quelle langue GameLift prise en charge par Amazon.

Avant d'exécuter Local, les éléments suivants doivent avoir été installés.

  • Une SDK version d'Amazon GameLift Server 3.1.5 à 4.x.

  • Java 8

Tester un serveur de jeu

Si vous souhaitez uniquement tester votre serveur de jeu, vous pouvez l'utiliser AWS CLI pour simuler des appels de clients de jeu vers le service Amazon GameLift Local. Vous pouvez ainsi vérifier que votre serveur de jeux se comporte comme prévu dans les circonstances suivantes :

  • Le serveur de jeu démarre correctement et initialise le GameLift serveur SDK Amazon.

  • Dans le cadre du processus de lancement, le serveur de jeu informe Amazon GameLift qu'il est prêt à héberger des sessions de jeu.

  • Le serveur de jeu envoie l'état de santé à Amazon GameLift toutes les minutes pendant l'exécution.

  • Le serveur de jeux répond aux demandes de démarrage d'une nouvelle session de jeu.

  1. Démarrez Amazon GameLift Local.

    Ouvrez une fenêtre d'invite de commande, accédez au répertoire contenant le fichier GameLiftLocal.jar et exécutez-le. Par défaut, Local écoute les demandes des clients de jeu sur le port 8080. Pour spécifier un autre numéro de port, utilisez le paramètre -p, comme indiqué dans l'exemple suivant:

    java -jar GameLiftLocal.jar -p 9080

    Une fois que Local a démarré, les journaux indiquent que deux serveurs locaux ont été lancés, l'un qui écoute votre serveur de jeux et l'autre qui écoute votre client de jeu ou l' AWS CLI. Les journaux continuent de signaler l'activité sur les deux serveurs locaux, y compris la communication vers et depuis les composants de votre jeu.

  2. Démarrez votre serveur de jeux.

    Démarrez votre serveur de jeu GameLift intégré à Amazon localement. Il n'est pas nécessaire de modifier le point de terminaison du serveur de jeux.

    Dans la fenêtre d'invite de commande locale, les messages du journal indiquent que votre serveur de jeu s'est connecté au service Amazon GameLift Local. Cela signifie que votre serveur de jeu a correctement initialisé le GameLift serveur Amazon SDK (avecInitSDK()). Il a appelé ProcessReady() avec les chemins d'accès aux journaux affichés et, en cas de succès, est prêt à héberger une session de jeu. Pendant le fonctionnement du serveur de jeu, Amazon GameLift enregistre chaque rapport d'état de santé du serveur de jeu. L'exemple de message de journal suivant illustre l'intégration réussie d'un serveur de jeux :

    16:50:53,217 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - SDK connected: /127.0.0.1:64247 16:50:53,217 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - SDK pid is 17040, sdkVersion is 3.1.5 and sdkLanguage is CSharp 16:50:53,217 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - NOTE: Only SDK versions 3.1.5 and above are supported in GameLiftLocal! 16:50:53,451 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - onProcessReady received from: /127.0.0.1:64247 and ackRequest requested? true 16:50:53,543 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - onProcessReady data: logPathsToUpload: "C:\\game\\logs" logPathsToUpload: "C:\\game\\error" port: 1935 16:50:53,544 INFO || - [HostProcessManager] nioEventLoopGroup-3-1 - Registered new process true, true, 16:50:53,558 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - onReportHealth received from /127.0.0.1:64247 with health status: healthy

    Les messages éventuels d'erreur ou d'avertissement sont les suivants :

    • Erreur : « Impossible ProcessReady de trouver un processus avec le PID : <process ID>! Init SDK () a-t-il été invoqué ? »

    • Avertissement : « L'état du processus existe déjà pour le processus avec PID : <process ID>! Est-ce que ProcessReady (...) est invoqué plusieurs fois ? »

  3. Démarrez le AWS CLI.

    Une fois que votre serveur de jeux a appelé ProcessReady() avec succès, vous pouvez démarrer les appels clients. Ouvrez une autre fenêtre d'invite de commande et démarrez l' AWS CLI . AWS CLI Par défaut, il utilise le point de terminaison du service GameLift Web Amazon. Vous devez remplacer celui-ci par le point de terminaison Local dans toutes les demandes à l'aide du paramètre --endpoint-url, comme indiqué dans l'exemple de demande suivant.

    AWS gamelift describe-game-sessions --endpoint-url http://localhost:9080 --fleet-id fleet-123

    Dans la fenêtre d'invite de AWS CLI commande, AWS gamelift les commandes donnent lieu à des réponses, comme indiqué dans le manuel de référence des AWS CLI commandes.

  4. Créez une session de jeu.

    Avec le AWS CLI, soumettez une demande CreateGameSession(). La demande doit respecter la syntaxe attendue. Pour Local, le paramètre FleetId peut être défini avec toute chaîne valide (^fleet-\S+).

    AWS gamelift create-game-session --endpoint-url http://localhost:9080 --maximum-player-session-count 2 --fleet-id fleet-1a2b3c4d-5e6f-7a8b-9c0d-1e2f3a4b5c6d

    Dans la fenêtre d'invite de commande locale, les messages du journal indiquent qu'Amazon GameLift Local a envoyé un onStartGameSession rappel à votre serveur de jeu. Si une session de jeu a été créée avec succès, votre serveur de jeux répond en appelant ActivateGameSession.

    13:57:36,129 INFO || - [SDKInvokerImpl] Thread-2 - Finished sending event to game server to start a game session: arn:aws:gamelift:local::gamesession/fleet-1a2b3c4d-5e6f-7a8b-9c0d-1e2f3a4b5c6d/gsess-ab423a4b-b827-4765-aea2-54b3fa0818b6. Waiting for ack response.13:57:36,143 INFO || - [SDKInvokerImpl] Thread-2 - Received ack response: true13:57:36,144 INFO || - [CreateGameSessionDispatcher] Thread-2 - GameSession with id: arn:aws:gamelift:local::gamesession/fleet-1a2b3c4d-5e6f-7a8b-9c0d-1e2f3a4b5c6d/gsess-ab423a4b-b827-4765-aea2-54b3fa0818b6 created13:57:36,227 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - onGameSessionActivate received from: /127.0.0.1:60020 and ackRequest requested? true13:57:36,230 INFO || - [SDKListenerImpl] nioEventLoopGroup-3-1 - onGameSessionActivate data: gameSessionId: "arn:aws:gamelift:local::gamesession/fleet-1a2b3c4d-5e6f-7a8b-9c0d-1e2f3a4b5c6d/gsess-abcdef12-3456-7890-abcd-ef1234567890"

    Dans la AWS CLI fenêtre, Amazon GameLift répond avec un objet de session de jeu comprenant un identifiant de session de jeu. Notez que le statut de la nouvelle session de jeu est Activating. Le statut passe à Actif une fois que votre serveur de jeu l'appelle. ActivateGameSession Si vous souhaitez voir le statut modifié, utilisez le AWS CLI to callDescribeGameSessions().

    { "GameSession": { "Status": "ACTIVATING", "MaximumPlayerSessionCount": 2, "FleetId": "fleet-1a2b3c4d-5e6f-7a8b-9c0d-1e2f3a4b5c6d", "GameSessionId": "arn:aws:gamelift:local::gamesession/fleet-1a2b3c4d-5e6f-7a8b-9c0d-1e2f3a4b5c6d/gsess-abcdef12-3456-7890-abcd-ef1234567890", "IpAddress": "127.0.0.1", "Port": 1935 } }

Tester un serveur et un client de jeu

Pour vérifier l'intégration complète de votre jeu, y compris la connexion de joueurs à des parties, vous pouvez exécuter votre serveur de jeux et votre client de jeu localement. Cela vous permet de tester les appels programmatiques de votre client de jeu vers Amazon GameLift Local. Vous pouvez vérifier les actions suivantes :

  • Le client du jeu envoie avec succès des AWS SDK demandes au service Amazon GameLift Local, notamment pour créer des sessions de jeu, récupérer des informations sur les sessions de jeu existantes et créer des sessions de joueur.

  • Le serveur de jeux valide correctement les joueurs lorsqu'ils tentent de rejoindre une session de jeu. Pour les joueurs validés, le serveur de jeux peut récupérer les données des joueurs (si la fonction a été mise en œuvre).

  • Le serveur de jeux signale l'abandon d'une connexion quand un joueur quitte le jeu.

  • Le serveur de jeux rapporte la fin d'une session de jeu.

  1. Démarrez Amazon GameLift Local.

    Ouvrez une fenêtre d'invite de commande, accédez au répertoire contenant le fichier GameLiftLocal.jar et exécutez-le. Par défaut, Local écoute les demandes des clients de jeu sur le port 8080. Pour spécifier un autre numéro de port, utilisez le paramètre -p, comme indiqué dans l'exemple suivant.

    ./gamelift-local -p 9080

    Une fois que Local a démarré, vous voyez que les journaux affichent le lancement de deux serveurs locaux, l'un qui écoute votre serveur de jeux et l'autre qui écoute votre client de jeu ou l' AWS CLI.

  2. Démarrez votre serveur de jeux.

    Démarrez votre serveur de jeu GameLift intégré à Amazon localement. Pour plus d'informations sur les journaux de messages, consultez Tester un serveur de jeu.

  3. Configurez votre client de jeu pour Local et démarrez-le.

    Pour utiliser votre client de jeu avec le service Amazon GameLift Local, vous devez apporter les modifications suivantes à la configuration de votre client de jeu, comme décrit dans Configurer Amazon GameLift sur un service de backend :

    • Modifiez l'objet ClientConfiguration afin de pointer vers votre point de terminaison Local, tel que http://localhost:9080.

    • Définissez une valeur d'ID de flotte cible. Pour Local, vous n'avez pas besoin d'un ID de flotte réel ; définissez la flotte cible avec une chaîne valide de votre choix (^fleet-\S+), comme fleet-1a2b3c4d-5e6f-7a8b-9c0d-1e2f3a4b5c6d.

    • Définissez les AWS informations d'identification. Pour Local, vous n'avez pas besoin d'informations d'identification AWS réelles ; vous pouvez définir la clé d'accès et la clé secrète avec toute chaîne de votre choix.

    Dans la fenêtre d'invite de commande locale, une fois que vous avez démarré le client du jeu, les messages du journal doivent indiquer qu'il a initialisé le service Amazon GameLiftClient et qu'il a bien communiqué avec le GameLift service Amazon.

  4. Testez les appels des clients du jeu vers le GameLift service Amazon.

    Vérifiez que votre client de jeu passe avec succès l'un ou l'ensemble des API appels suivants :

    Dans la fenêtre d'invite de commande Local, seuls les appels à CreateGameSession() se traduisent par des messages de journaux. Les messages de journal s'affichent lorsqu'Amazon GameLift Local invite votre serveur de jeu à démarrer une session de jeu (onStartGameSessionrappel) et obtient un résultat ActivateGameSession lorsque votre serveur de jeu l'invoque. Dans la AWS CLI fenêtre, tous les API appels donnent lieu à des réponses ou à des messages d'erreur, comme indiqué.

  5. Vérifiez que votre serveur de jeux valide les nouvelles connexions de joueur.

    Après avoir créé une session de jeu et une session joueur, établissez une connexion directe à la session de jeu.

    Dans la fenêtre d'invite de commande Local, les messages de journaux doivent indiquer que le serveur de jeux a envoyé une demande AcceptPlayerSession() pour valider la nouvelle connexion de joueur. Si vous utilisez le AWS CLI pour appelerDescribePlayerSessions(), le statut de la session du joueur devrait passer de Réservée à Actif.

  6. Vérifiez que votre serveur de jeu communique l'état du jeu et du joueur au GameLift service Amazon.

    Pour GameLift qu'Amazon puisse gérer la demande des joueurs et communiquer correctement les statistiques, votre serveur de jeu doit signaler les différents statuts à Amazon GameLift. Vérifiez que Local enregistre les événements liés aux actions suivantes. Vous pouvez également utiliser le pour AWS CLI suivre les changements de statut.

    • Le joueur se déconnecte d'une session de jeu. Les messages du journal Amazon GameLift Local devraient indiquer que votre serveur de jeu appelleRemovePlayerSession(). Un appel de l' AWS CLI à DescribePlayerSessions() doit refléter un changement d'état d'Active en Completed. Vous pouvez également appeler DescribeGameSessions() pour vérifier que le nombre de joueurs en cours de la session a diminué d'une unité.

    • Fin de la session de jeu : les messages du journal Amazon GameLift Local devraient indiquer que votre serveur de jeu appelleTerminateGameSession().

      Note

      Le conseil précédent était d'appeler à TerminateGameSession() la fin d'une session de jeu. Cette méthode est obsolète avec Amazon GameLift Server SDK v4.0.1. Consultez Mettre fin à une session de jeu.

    • Le processus du serveur est terminé : les messages du journal Amazon GameLift Local devraient indiquer que votre serveur de jeu appelleProcessEnding(). Un AWS CLI appel à DescribeGameSessions() doit refléter un changement de statut de Active à Terminated (ouTerminating).

Variations avec les produits locaux

Lorsque vous utilisez Amazon GameLift Local, gardez à l'esprit les points suivants :

  • Contrairement au service GameLift Web Amazon, Local ne suit pas l'état de santé d'un serveur et n'initie pas le onProcessTerminate rappel. Local arrête simplement la journalisation des rapports d'état pour le serveur de jeux.

  • Pour les appels au AWS SDK, la flotte IDs n'est pas validée et peut être n'importe quelle valeur de chaîne répondant aux exigences des paramètres (^fleet-\S+).

  • Les sessions de jeu IDs créées avec Local ont une structure différente. Ils incluent la chaîne local, comme illustré ici :

    arn:aws:gamelift:local::gamesession/fleet-123/gsess-56961f8e-db9c-4173-97e7-270b82f0daa6