Présentation d’outils pour implémenter une solution de test de non régression dans une architecture microservices avec les technologies, Spring Boot, Kafka, PostgreSQL, MongoDB, et ElasticSearch.
Certains de ces microservices communiquent avec une base de données. Parfois, un microservice est responsable de publier un message sur un topic, un autre est responsable d’écouter et réagir face au message reçu sur un topic.
Les problématiques soulevées avant de pouvoir tester le bon fonctionnement d’une fonctionnalité au sein de cette architecture :
Comment tester l’existence d’un objet sur un topic Kafka ?
Comment tester l’existence d’un enregistrement dans une base de données PostgresSQL, MongoDB, Elastic Search ?
Les outils pour tester cette architecture
Postman Newman : Exécuter le scénario de recette
Fonctionnalités
Exécuter des scénarios de test. Les tests sont des enchaînements d’appel API HTTP.
Xiaomi Mi 9T RAW & JPEG import via USB C to USB C connection OTG Android
How to import RAW photos from Fujifilm to your Android phone ?
Use the USB OTG option on Android !
Example with the Xiaomi Mi 9T and Fujifilm X-S10.
Connect a USB C to USB C between your phone and your Fujifilm Camera.
Adobe Lightroom
If you have the Adobe Lightroom App installed on your phone, you can scan all JPEG, RAW files and Videos files in the memory card of your Camera. You can select which one to import directly into a Lightroom Album.
Google Photos
Google Photos can be used to navigate through your files, and import them.
Android File Manager
Lastly, with the Android file Manager the default file manager installed on your phone, example here with the file manager of the Xiaomi MI 9 T, import into a folder in the phone memory.
The advantage of directly connect the camera to the phone with a USB cable, it allows you to import the RAW files. Then you can edit RAW files directly into your Adobe Lightroom App.
Ce guide liste des astuces pour améliorer votre productivité en tant que développeur.
Avoir une définition de ce qui est terminée akka Definition of Done et éventuellement un Definition of Ready (méthode agile). Cela t’obligera à être rigoureux. À partir de quel moment on peut considérer que ta tâche est terminée. Lorsque le client est satisfait ? Lorsque les critères d’acceptation sont validés. Lorsque le testeur à validé la recette ?
Connaitre son rôle en tant que développeur Partons du principe que le rôle du développeur est d’apporter de la valeur à l’entreprise, c’est sa priorité numéro 1. Poses toi la question suivante dans chaque tâche que tu entames “Est-ce que je vais apporter de la valeur à mon entreprise en faisant cela ?” Si tu as un doute pose la question à ton collègue ou un supérieur.
Résister au réfactoring quand ce n’est pas nécessaire On peut distinguer deux situations réfactoring :
Tu as besoin de refactorer du code pour faciliter l’implémentation d’une fonctionnalité.
Tu souhaites refactorer, car une partie du code n’est pas lisible (selon toi), ou n’est pas au goût du jour.
C’est aussi une façon de te différencier en ne tombant pas dans le piège du refactoring. En effet beaucoup de développeurs auront pour réflexe de critiquer ce qui a été fait a telle endroit du code. Alors comment se différencier de ces développeurs de façon intelligente. Déjà avant de critiquer ouvertement ou même avec un collègue assures toi d’avoir déjà une solution, de comment améliorer la chose. Où sinon tournes ta phrase. En partant du principe que tu ne critiques pas, mais plutôt que tu demandes de l’aide à améliorer une partie du code.
Tester son application
En la démarrant sur mon poste.
Je teste l’application une fois déployée sur l’environnement. (développement|recette) Cela me permet de :
Voir si je n’aurai pas oublié certains cas de test.
Vérifier mes logs, voir s’ils sont bien contextualisés. Même si mes tests s’exécutent correctement. Démarrer l’application sur mon poste
Je demande à une personne de tester mon application.
Vérifier les logs une fois l’application déployée. Ok, j’ai pensé à mettre des logs dans mon implémentation, mais quand est-il vraiment lorsque j’exécute mon application ? Est-ce qu’ils sont suffisamment contextualisés ?
Relire ma propre Merge|Pull Request À la recherche de faute d’orthographe. De TODO oublié dans le code source. S’il y a des parties du code dont je ne suis pas confiant, j’ajoute un commentaire pour attirer l’attention du relecteur et lui demander un avis.
Éviter de faire du copier/coller de code source Ça peut paraître contre productif. Mais prendre le temps de réécrire un morceau de code trouvé sur Internet. Surtout si c’est du code qu’on ne connaît pas. D’une part permet de comprendre ligne après ligne ce que le code fait. Mais surtout ça me permet de le mémoriser.
Utiliser les raccourcis clavier
Quand je code, j’utilise régulièrement l’autocomplétion. C’est un moyen d’apprendre de nouvelles méthodes ou fonctionnalités. Également lire la documentation du code. Parfois, tu trouveras des informations pertinentes uniquement dans la documentation du code source et pas dans la documentation officielle du site web. Apprends à utiliser d’autres fonctionnalités comme “call hiérarchie”. https://jetbrains.developpez.com/tutoriel/top-dix-plugins-intellij-idea/
Réfléchir à haute voix (think Loud) Le principe est simple lorsque tu es bloqué pendant un certain temps, exprimes ton problème à haute voix sans pour autant demander de l’aide à un collègue. Peut-être un collègue aura l’oreille attentive et t’apportera une solution.
Prendre le temps de connaître son IDE, navigateur, système d’exploitation
Utiliser des générateurs en ligne Je dois générer un mot de passe, pour un énième site ou je souhaite m’inscrire. Vient le moment de s’inscrire et de choisir un mot passe, inutile de perdre du temps en trouvant la bonne combinaison, je cherche un générateur de mot de passe sur Google. Il en existe même pour générer sa signature de mail.
Ne pas taper plus de 2 touches sur le clavier sans regarder son écran. L’autocomplétion est partout, je ne peux pas me permettre d’écrire un mot complet en regardant uniquement le clavier, Alors que l’autocomplétion suggère peut-être le mot que je souhaite taper.
Cultiver sa passion pour son métier. Où apprendre ce qui nous passionnes dans les tâches du quotidien, si je n’éprouve pas encore de passion. Si tu n’es pas passionné, tu ne comprendras pas pourquoi un collègue sur le même poste est plus productif que toi. Tu n’essayeras même pas d’observer sa façon de travail, pour copier de bonnes idées. Aussi, tu n’auras pas recours à ton imagination pour essayer de t’améliorer.
Développer son expertise technique. Je peux approfondir mes connaissances sur l’une des technos que j’utilises.
Travaille sur un Side Project C’est le premier élément de cette liste. C’est la façon la plus amusante d’apprendre.
Faire de la veille ciblée Pourquoi ciblé ? Rappel toi, tu dois apporter de la valeur dans le milieu dans lequel tu évolues. Ta veille doit donc cibler les technos/domaines avec lesquels tu interagis lors de ton travail.
Acheter un livre sur une technologie Les livres techniques, peuvent être difficiles à terminer. L’objectif ne sera pas forcément de lire ce livre de A à Z. En revanches, tu t’attarderas sur le sommaire, repère les sujets que tu ne maîtrises pas. Et concentre ta lecture sur ces parties du livre. En étant conscient de tous les sujets abordés dans ton livre. Le jour où tu auras besoin d’une solution à un problème technique, tu sauras où chercher dans ce livre.
Suivre une formation N’attends pas que ton entreprise te propose une formation. Suis une formation gratuite ou payante. Les formations ont aussi des sommaires. Cible lorsque cela est possible les parties de la formation les plus pertinentes. Tu peux suivre la formation en entier. Mais tu en tireras plus si tu commences tout de suite à mettre en pratique ce que tu apprends dans un mini projet POC ou en prenant des notes sur une feuille blanche.
Écouter des podcasts
Regarder les vidéos ou écouter les podcasts en vitesse accélérée 1.75x ou 2x.
Je ne serai pas productif sans une bonne nuit de sommeil.
Comment héberger un site WordPress gratuitement, sans publicité ? Avec la possibilité d’installer des extensions et le thème de son choix.
Avantages :
Certificat SSL gratuit
Nom de domaine personnalisé
Inconvénients :
Lenteur du site, dû aux faibles ressources allouées pour le site gratuit.
Tout cela est disponible dans l’offre World Lite de Planethoster gratuitement. Ce n’est pas l’offre qui est la plus mise en avant, mais en cherchant bien elle est bien présente sur le site.
Créer votre site WordPress sur PlanetHoster gratuitement
En 2021-2022 les outils no code et d’automatisation sont en vogues, Planethoster est l’un des seuls fournisseur d’hébergement qui propose des APIs pour gérer :
Un fichier JSON contenant la liste des noms des caméras est facilement récupérable depuis la console de développement.
D’ailleurs, on peut remarquer que le nombre d’éléments dans le JSON ne correspond pas au nombre de camera répertoriés sur le site. Le Fujifilm X-S10 est sorti en fin 2020 et est 4028e élément.
Au début, je pensais qu’avec cette liste, j’aurais pu facilement déterminer les URLs.
En partant du principe que le premier espace rencontré serait à remplacer par un _. Et les espaces suivant sont à remplacer par un -.
Example :
Fujifilm X-S10 ⇒ fujifilm_x-s10
Bien que cette règle fonctionne dans la plupart des cas, j’ai quand même trouvé certains cas où elle ne fonctionne pas.
Deuxième solution plus fiable, utiliser le formulaire qui sert de navigation en haut de la page.
Il suffira de copier chaque valeur du tableau dans le champ du formulaire, et de cliquer sur le bouton de recherche. Attendre le chargement de la page. Récupérer les informations. Recommencer avec la valeur suivante ceci plus de 4 000 fois.
Définir une méthodologie pour naviguer sur les 4 000 + pages
Code
Le script crawler digicamdb sera créé en s’inspirant des scripts précédant.
Difficultés rencontrées
Rien à voir, mais j’ai décidé de faire des enregistrements d’écrans. Et les transformer en GIF pour les inclure dans les articles coding sessions. Ça rajoute une perte de temps dans la progression vers la finalisation de l’application.
Il faut enregistrer l’écran, éditer la vidéo retirer les moments ennuyeux. Parfois transformer en zoomant, croppant des parties de la vidéo. Après l’export convertir en GIF. Une étape supplémentaire en plus de rédiger l’article 😆.
Points positifs
Pas de point de blocage pour l’instant, c’est encourageant.
Nouvelles problématiques
Coder, écrire un article coding session, et dans un même temps capturer, éditer ma progression sous forme de vidéo/GIF.
C’est apparemment quelqu’un qui c’est spécialisé dans le scraping de site web. Il propose les données du site digicamdb.com. Contre un paiement de $75.32, marrant, c’est ma prochaine cible.
Site très intéressant, je m’arrête là pour ce soir, il faut que visite plus en profondeur ce fameux site WordPress teoalida.com
Le script plante parfois pour accéder à une page. Lié à une erreur de chargement de la page. Cela induit une opération manuelle pour relancer le crawl. 😑
Points positifs
2ième script exécution ok partielle.
Nouvelles problématiques
Fixer les erreurs de chargement de la page lors de l’exécution du script.
Idée d’app. Pouvoir calculer le poids de son équipement appareil photo et voir quel stabilisateur serait approprié en fonction du poids supporté. (En écrivant ces lignes me vient une autre idée. Cette app pourrais aussi calculer le poids des équipements style trépieds, lumière, micro, batterie externe, disque dur, mais bon là ça devient fastidieux. Faut d’abord se concentrer sur une feature. Et cette feature doit être bien faite donc je disais…) Pour cette appli il me faut des données. À savoir les appareils photo noms et poids. Et les objectifs noms et poids.
Aucune base de données libre d’accès, n’est disponible ni d’API. En revanche, il existe des sites qui recenses des appareils photos et des objectifs.
Changeons de perspective internet est une base de données et les pages sont des tables.
Je veux récupérer des informations dans ces tables. Je vais devoir les crawler 😎.
Voici quelques sites qui semblent contenir les informations que je recherche.
Pour récupérer les données de dxomark il suffit d’ouvrir la console. Et regarder les appels HTTP.
Après analyse, il semblerait que les données de dxomark ne correspondent pas à ce que je recherche. Le poids de l’appareil photo n’est pas présent.
allphotolenses.com/lenses contient des informations sur les objectifs. Le nom et le poids de l’objectif sont présents. Même quelques images de l’objectif parfois 👌🏾.
En revanche, pour récupérer ces données ce n’est pas aussi simple que sur dxomark.
Les données ne sont pas requêtées depuis le client. Les pages sont soit statiques côté serveur ou généré côté serveur.
Du coup, il va falloir récupérer les informations directement dans la page HTML.
La première étape va consister à récupérer toutes les URLs des pages qui m’intéressent.
À savoir 3800+ URLs.
Seulement après avoir écrit et exécuté le 1er script je rendit compte que les URLs aurait pu facilement être deviné.
J’aurais pu générer ces URLs avec une boucle sur le nom des objectifs contenu dans le JSON récupéré précédemment. Passer plus de temps sur l’analyse m’aurait évité du temps perdu a développer ce premier script. Mais ce n’est pas plus mal. J’ai pu monter en compétences sur l’utilisation de Puppetteer et de valider mon choix de d’outil.
Objectifs
Base de données cameras.
Base de données objectifs.
Base de données sur Google Sheets
API de recherche GET cameras/ & GET lenses/ + Swagger
Crawler Nodejs
Code
Premier script permet de récupérer toutes les pages.
import { chromium } from 'playwright';
import * as fs from "fs";
(async () => {
const browser = await chromium.launch();
const page = await browser.newPage();
// START
const results = [];
const pageLenesSize = Array.from({ length: 239 }, (_, index) => index + 1);;
for (let i = 0; i < pageLenesSize.length; i++) {
await page.goto('<https://allphotolenses.com/lenses/>' + `p_${i + 1}.html`,
{ waitUntil: 'networkidle' });
console.log("iteration ", i)
const trLight = await page.$eval('.light_tr', e => {
const as = e.map(r => r.querySelector('a').href);
return as;
})
const trDark = await page.$eval('.dark_tr', e => {
const as = e.map(r => r.querySelector('a').href);
return as;
})
console.log('found', trLight.length, trDark.length)
console.log(trLight, trDark);
results.push(...trLight);
results.push(...trDark);
};
console.log("results length", results.length);
fs.writeFileSync('./paths.json', JSON.stringify(results));
// END
await browser.close();
})();
Difficultés rencontrées
Quel Framework choisir ?
Le choix ira pour Apfy Playwright.
Points positifs
JSON to Google Sheets api via Pipedream.
Réalisation d’un premier crawler avec Puppetteer.
Un premier script permet de récupérer les pages à crawler.
Le deuxième script va récupérer les informations sur la page.
Import du JSON généré dans notre API JSON To Google Sheets.
Nouvelles problématiques
Est-ce légal de réutiliser ces données accessibles publiquement dans une autre application ?
Est-ce légal d’exposer ces données via une API REST publique ?
Backpressure avec l’opérateur .delaysElements() sur le reactiveKafkaConsumerTemplate
On peut choisir la cadence à laquelle consommer chaque message. Il ne faudra pas oublier de positionner la configuration spring.kafka.consumer.max.poll.records=1 pour avoir l’effet escompté.