« Ruby on rails » : différence entre les versions

De wiki jackbot
Aller à la navigation Aller à la recherche
mAucun résumé des modifications
mAucun résumé des modifications
Ligne 6 : Ligne 6 :
<h1>Les générateurs</h1>
<h1>Les générateurs</h1>
Ruby on Rails vient avec bon nombres de scripts appelé des générateurs, qui on pour but d'aider au développement en créant les fondations d'une nouvelle application Rails.
Ruby on Rails vient avec bon nombres de scripts appelé des générateurs, qui on pour but d'aider au développement en créant les fondations d'une nouvelle application Rails.
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 160px;">
$ rails new blog
$ rails new blog
</pre>
</pre>


Va ainsi crée toute une arborescence :
Va ainsi crée toute une arborescence :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 160px;">
$ tree -d -L 2
$ tree -d -L 2
.
.
Ligne 47 : Ligne 47 :
<h1>Test du serveur</h1>
<h1>Test du serveur</h1>
Le coté pratique de RoR est que juste après avoir utilisé un générateur il est possible de démarrer le serveur avec la commande :
Le coté pratique de RoR est que juste après avoir utilisé un générateur il est possible de démarrer le serveur avec la commande :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 160px;">
$ rails server
$ rails server
</pre>
</pre>
Ligne 56 : Ligne 56 :
L'architecture MVC (Modèle Vue Contrôleur), permet de cloisonner correctement les différentes tâches.
L'architecture MVC (Modèle Vue Contrôleur), permet de cloisonner correctement les différentes tâches.


<h2>Modèle</h2>
<h2>Modèles</h2>
Les modèles sont des classes écrite en Ruby utilisées pour représenter les données et possiblement interagir avec la base de données au travers de : "Active Record"
Les modèles sont des classes écrite en Ruby utilisées pour représenter les données et possiblement interagir avec la base de données au travers de : "Active Record"


Pour créer un modèle la commande est la suivante :
Pour créer un modèle la commande est la suivante :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 500px;">
$ rails generate model Article title:string body:text
$ rails generate model Article title:string body:text
Running via Spring preloader in process 21517
Running via Spring preloader in process 21517
Ligne 78 : Ligne 78 :


La commande précédente se contente de créer les différents fichiers, mais sans modifier la base de données. Pour cela il faut exécuter la commande :
La commande précédente se contente de créer les différents fichiers, mais sans modifier la base de données. Pour cela il faut exécuter la commande :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 650px;">
$ rails db:migrate
$ rails db:migrate
== 20211105132513 CreateArticles: migrating ===================================
== 20211105132513 CreateArticles: migrating ===================================
Ligne 93 : Ligne 93 :


Exemple :
Exemple :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 650px;">
$ rails generate model ArticleTest title:string body:text
$ rails generate model ArticleTest title:string body:text
Running via Spring preloader in process 8929
Running via Spring preloader in process 8929
Ligne 114 : Ligne 114 :
<h3>Jouer avec les modèles</h3>
<h3>Jouer avec les modèles</h3>
Il est tout à fait possible de tester les modèles crées sans modifier l'application, pour ce faire il faut utiliser la console rails avec la commande :
Il est tout à fait possible de tester les modèles crées sans modifier l'application, pour ce faire il faut utiliser la console rails avec la commande :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 160px;">
$ rails console
$ rails console
</pre>
</pre>


Pour créer un nouvel article, mais sans pour autant le sauvegarder dans la base de données il faut utiliser la méthode "new" :
Pour créer un nouvel article, mais sans pour autant le sauvegarder dans la base de données il faut utiliser la méthode "new" :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 600px;">
article = Article.new(title: "Bonjour Rails", body: "Je suis sur rails!")
article = Article.new(title: "Bonjour Rails", body: "Je suis sur rails!")
</pre>
</pre>


À cette étape, seule la variable "article" contient des données, l'appel des méthodes "Article.find(1)", "Article.all", ne donnera rien car le modèle Article n'a pas encore interagit avec la base de données.
À cette étape, seule la variable "article" contient des données, l'appel des méthodes "Article.find(1)", "Article.all", ne donnera rien car le modèle Article n'a pas encore interagit avec la base de données.
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 70%;">
> article
> article
  => #<Article id: nil, title: "Bonjour Rails", body: "Je suis sur rails!", created_at: nil, updated_at: nil>  
  => #<Article id: nil, title: "Bonjour Rails", body: "Je suis sur rails!", created_at: nil, updated_at: nil>  
Ligne 136 : Ligne 136 :


Pour modifier la base de données et inclure les informations de la variable "article" il faut utiliser la commande :
Pour modifier la base de données et inclure les informations de la variable "article" il faut utiliser la commande :
<pre style="color: silver; background: black;">
<pre style="color: silver; background: black; width: 70%;">
> article.save
> article.save
   TRANSACTION (0.1ms)  begin transaction
   TRANSACTION (0.1ms)  begin transaction
Ligne 145 : Ligne 145 :


On peut voir apparaître avec cette commande : " INSERT INTO "articles" ", la base de données a donc bien été modifiée. Maintenant la commande :
On peut voir apparaître avec cette commande : " INSERT INTO "articles" ", la base de données a donc bien été modifiée. Maintenant la commande :
<pre style="color: silver; background: black;">
 
<pre style="color: silver; background: black; width: 70%;">
> Article.find(1)
> Article.find(1)
   Article Load (0.3ms)  SELECT "articles".* FROM "articles" WHERE "articles"."id" = ? LIMIT ?  [["id", 1], ["LIMIT", 1]]
   Article Load (0.3ms)  SELECT "articles".* FROM "articles" WHERE "articles"."id" = ? LIMIT ?  [["id", 1], ["LIMIT", 1]]
  => #<Article id: 1, title: "Bonjour Rails", body: "Je suis sur rails!", created_at: "2021-11-06 09:23:32.737847000 +0000", updated_at: "2021-11-06 09:23:32.737847000 +0000">  
  => #<Article id: 1, title: "Bonjour Rails", body: "Je suis sur rails!", created_at: "2021-11-06 09:23:32.737847000 +0000", updated_at: "2021-11-06 09:23:32.737847000 +0000">  
</pre>
</pre>
Renvoie bien des données.
Renvoie bien des données.


<h2>Contrôleurs</h2>
Au vu de l'acronyme MVC, après les modèles on serait tenté de continuer avec les vues, cependant l'élément qui va permettre de chercher et d'afficher la vue est le contrôleur. Mais avant d'attaquer ce morceau, il va falloir faire un détour par les routes.
<h3>Les routes</h3>
Le rôles des routes est de reconnaître les URLs et de déclencher le contrôleur adéquat. Le fichier à modifier est : "config/routes.rb". La syntaxe à utiliser est la suivante :
<span style="background: #00da03;font-size:150%;">Verbe_HTTP 'URL', to: 'contrôleur#méthode'</span>
*Verbe_HTTP, est la méthode avec laquelle la requête sera effectuée : get, post, patch, delete et root.
*URL, est simplement l'adresse qui doit déclencher le contrôleur
*contrôleur, correspond au nom du fichier dans le dossier "app/controllers/
*méthode, les contrôleurs étant des classes écrite en Ruby, elles possèdent des méthodes


<h4>Les verbes HTTP</h4>
*get est simplement le passage par l'URL, historiquement limité à 255 caractères
*post est utilisé pour envoyer des données au serveur
*Patch est utilisé pour faire des mises à jours sur les données
*delete pour effacer des données
*root est un peu particulier car il s'agit simplement de demander la page par défaut





Version du 6 novembre 2021 à 12:13

Ruby on rails est un framework web libre écrit en Ruby. Il est basé sur l'architecture Modèle-Vue-Contrôleur (MVC). Il a pour but de respecter deux principes fondamentaux de la programmation

  • DRY : Don't repeat yourself, ne vous répétez pas
  • Convention Over Configuration, Convention plutôt que configuration

Les générateurs

Ruby on Rails vient avec bon nombres de scripts appelé des générateurs, qui on pour but d'aider au développement en créant les fondations d'une nouvelle application Rails.

$ rails new blog

Va ainsi crée toute une arborescence :

$ tree -d -L 2
.
└── blog
    ├── app
    ├── bin
    ├── config
    ├── db
    ├── lib
    ├── log
    ├── node_modules
    ├── public
    ├── storage
    ├── test
    ├── tmp
    └── vendor
  • app contient les models, views, helpers, mailers, channels, jobs, et assets pour l'application.
  • bin contient les scripts permettant démarrer de l'application, ainsi que d'autres script pour définir, mettre à jour, déployer ou exécuter l'application.
  • config contient la configuration des routes, bases de données et autres.
  • db contient sans surprise la base de données, ainsi que les migrations.
  • lib contient les modules pour l'application.
  • log contient simplement les logs.
  • public contient des fichiers statiques ainsi que des ressources compilées. Quand l'application est lancée, ce dossier est exposé tel quel.
  • storage stockage actif de fichier.
  • test contient les tests unitaires
  • tmp contient des fichiers temporaires
  • vendor contient des gems externe

On y trouve également les fichiers suivant :

  • Gemfile qui permet de spécifier les dépendances
  • package.json qui permet de spécifier les dépendances vis à vis de npm

Test du serveur

Le coté pratique de RoR est que juste après avoir utilisé un générateur il est possible de démarrer le serveur avec la commande :

$ rails server

Vous pourrez voir le résultat à l'adresse http://localhost:3000 Il s'agit simplement d'une page visant à prouver que le serveur est lancé et RoR est opérationnel.

Notions MVC

L'architecture MVC (Modèle Vue Contrôleur), permet de cloisonner correctement les différentes tâches.

Modèles

Les modèles sont des classes écrite en Ruby utilisées pour représenter les données et possiblement interagir avec la base de données au travers de : "Active Record"

Pour créer un modèle la commande est la suivante :

$ rails generate model Article title:string body:text
Running via Spring preloader in process 21517
      invoke  active_record
      create    db/migrate/20211105132513_create_articles.rb
      create    app/models/article.rb
      invoke    test_unit
      create      test/models/article_test.rb
      create      test/fixtures/articles.yml

Vous pouvez voir que cette commande à créé de nombreux fichiers

  • 20211105132513_create_articles.rb qui contient les modifications à apporter à la base de données
  • article.rb qui est le fichier contenant la classe en Ruby
  • article_test.rb les tests unitaires pour la classe
  • articles.yml (rôle inconnu ... pour l'instant)

La commande précédente se contente de créer les différents fichiers, mais sans modifier la base de données. Pour cela il faut exécuter la commande :

$ rails db:migrate
== 20211105132513 CreateArticles: migrating ===================================
-- create_table(:articles)
   -> 0.0020s
== 20211105132513 CreateArticles: migrated (0.0020s) ==========================

C'est ici que vont commencer à rentrer en jeu les conventions, car comme vous pouvez le voir, la table se nomme : "articles", donc en minuscule et au pluriel.

Conventions :

  • La convention de nommage sur les modèles est d'écrire tout attaché mais avec une majuscule pour la première lettre de chaque mot : "Table", "NouvelleTable"
  • Le nom des tables dans la base de données sera toujours en minuscule, les mots séparé par des '_' et au pluriel. Exemple : "tables", "nouvelle_tables"

Exemple :

$ rails generate model ArticleTest title:string body:text
Running via Spring preloader in process 8929
      invoke  active_record
      create    db/migrate/20211106075639_create_article_tests.rb
      create    app/models/article_test.rb
      invoke    test_unit
      create      test/models/article_test_test.rb
      create      test/fixtures/article_tests.yml

$ rails db:migrate
== 20211106075639 CreateArticleTests: migrating ===============================
-- create_table(:article_tests)
   -> 0.0022s
== 20211106075639 CreateArticleTests: migrated (0.0023s) ======================

On peut voir ici qu'en nommant un modèle "ArticleTest", donc en respectant la convention d'écrire tout attaché, mais avec une majuscule au début de chaque mot. Rails va être capable de créer la table : "article_tests" donc tout en minuscule, les mots séparés par '_' et au pluriel.

Jouer avec les modèles

Il est tout à fait possible de tester les modèles crées sans modifier l'application, pour ce faire il faut utiliser la console rails avec la commande :

$ rails console

Pour créer un nouvel article, mais sans pour autant le sauvegarder dans la base de données il faut utiliser la méthode "new" :

article = Article.new(title: "Bonjour Rails", body: "Je suis sur rails!")

À cette étape, seule la variable "article" contient des données, l'appel des méthodes "Article.find(1)", "Article.all", ne donnera rien car le modèle Article n'a pas encore interagit avec la base de données.

> article
 => #<Article id: nil, title: "Bonjour Rails", body: "Je suis sur rails!", created_at: nil, updated_at: nil> 

> Article.find(1)
  Article Load (0.2ms)  SELECT "articles".* FROM "articles" WHERE "articles"."id" = ? LIMIT ?  [["id", 1], ["LIMIT", 1]]
Traceback (most recent call last):
        1: from (irb):8
ActiveRecord::RecordNotFound (Couldn't find Article with 'id'=1)

Pour modifier la base de données et inclure les informations de la variable "article" il faut utiliser la commande :

> article.save
  TRANSACTION (0.1ms)  begin transaction
  Article Create (0.5ms)  INSERT INTO "articles" ("title", "body", "created_at", "updated_at") VALUES (?, ?, ?, ?)  [["title", "Bonjour Rails"], ["body", "Je suis sur rails!"], ["created_at", "2021-11-06 09:23:32.737847"], ["updated_at", "2021-11-06 09:23:32.737847"]]
  TRANSACTION (4.5ms)  commit transaction
 => true 

On peut voir apparaître avec cette commande : " INSERT INTO "articles" ", la base de données a donc bien été modifiée. Maintenant la commande :

> Article.find(1)
  Article Load (0.3ms)  SELECT "articles".* FROM "articles" WHERE "articles"."id" = ? LIMIT ?  [["id", 1], ["LIMIT", 1]]
 => #<Article id: 1, title: "Bonjour Rails", body: "Je suis sur rails!", created_at: "2021-11-06 09:23:32.737847000 +0000", updated_at: "2021-11-06 09:23:32.737847000 +0000"> 

Renvoie bien des données.

Contrôleurs

Au vu de l'acronyme MVC, après les modèles on serait tenté de continuer avec les vues, cependant l'élément qui va permettre de chercher et d'afficher la vue est le contrôleur. Mais avant d'attaquer ce morceau, il va falloir faire un détour par les routes.

Les routes

Le rôles des routes est de reconnaître les URLs et de déclencher le contrôleur adéquat. Le fichier à modifier est : "config/routes.rb". La syntaxe à utiliser est la suivante :

Verbe_HTTP 'URL', to: 'contrôleur#méthode'

  • Verbe_HTTP, est la méthode avec laquelle la requête sera effectuée : get, post, patch, delete et root.
  • URL, est simplement l'adresse qui doit déclencher le contrôleur
  • contrôleur, correspond au nom du fichier dans le dossier "app/controllers/
  • méthode, les contrôleurs étant des classes écrite en Ruby, elles possèdent des méthodes

Les verbes HTTP

  • get est simplement le passage par l'URL, historiquement limité à 255 caractères
  • post est utilisé pour envoyer des données au serveur
  • Patch est utilisé pour faire des mises à jours sur les données
  • delete pour effacer des données
  • root est un peu particulier car il s'agit simplement de demander la page par défaut