Skip to content

bilalb/ios-advanced-technical-test-destinationguide

Repository files navigation

Introduction

Philosophie

Chez Evaneos, nous accordons beaucoup d'importance à la qualité du code et à la qualité de l'expérience utilisateur de nos produits.

Nous souhaitons à travers ce test voir tes capacités en développement. La maintenabilité et la clarté de ton code sont pour nous des éléments très important. N'hésite donc pas à faire attention aux détails et à être rigoureux.

Lors de la restitution on s'intéressera aux raisons de tes décisions et aux discussions que nous pourrons avoir autour.

Le test

Dans ce test, tu vas reprendre du code.

Il s'agit d'une petite app qui comporte une vue qui affiche des destinations provenant d'une fake API qui ne fonctionne pas très bien ;) Lorsque l'utilisateur sélectionne une destination, une vue détail est présentée et elle contient une webview.

Ce test comporte 2 parties. Une première partie de refactorisation du code existant. Dans la seconde tu vas devoir ajouter une fonctionnalité.

Pour faire ce test, tu peux forker ce repo et faire l'implémentation de ton coté, tu nous enverras ensuite l'URL de ton repo.

N'hésite pas à nous solliciter si tu as des questions.

1. Refactorer le code existant

La première partie du test consiste à refactorer le code existant en MVVM et à adopter des bonnes pratiques.

  • Nous ne voulons pas voir de completion block. Utilise Concurrency et/ou Combine.
  • Lors de la restitution le code de DestinationFetchingService ne devra pas avoir été changé. C'est le seul code autorisé à utiliser des completion blocks ;)

2. Ajouter la fonctionnalité "Destinations récentes"

Nous souhaitons ajouter une fonctionnalité qui sauvegarde les destinations précedemment consultées selon cette maquette.

  • Pour stocker ces valeurs tu peux utiliser UserDefaults.
  • Si la UI est réactive c'est un plus.
  • Nous aimerions voir quelques tests que tu juges utiles. Si tu peux faire cette partie en TTD c'est un plus.

Règles

  • Limite les dépendances externes et justifie leur utilisation.
  • Essaie de faire des commits régulièrement (par exemple étape par étape).
  • Le code de DestinationFetchingService ne devra pas avoir changé.

Bonus : UI/UX

Cette partie est facultative. Si tu as du temps et que tu souhaites nous montrer davantage de choses, tu peux améliorer l'expérience avec par exemple un loader, un meilleur affichage des erreurs, ou faire de la UI (UIKit ou SwiftUI) complètement ou partiellement pour la vue détail. Tu peux t'inspirer de cette maquette.

Si tu ne fais pas cette partie ce n'est pas éliminatoire. Nous pourrons aussi simplement discuter de ce que tu aurais vu ou pas, quelle approche etc.

Bonne chance !

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages