<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Isabella Robinson</title>
    <description>The latest articles on DEV Community by Isabella Robinson (@isabellarobinson).</description>
    <link>https://dev.to/isabellarobinson</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F580826%2F05e0163a-1190-4b2a-bc4f-3ea7298d0d4a.png</url>
      <title>DEV Community: Isabella Robinson</title>
      <link>https://dev.to/isabellarobinson</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/isabellarobinson"/>
    <language>en</language>
    <item>
      <title>Test </title>
      <dc:creator>Isabella Robinson</dc:creator>
      <pubDate>Wed, 17 Feb 2021 13:00:08 +0000</pubDate>
      <link>https://dev.to/isabellarobinson/test-5181</link>
      <guid>https://dev.to/isabellarobinson/test-5181</guid>
      <description>&lt;h1&gt;
  
  
  React Testing
&lt;/h1&gt;

&lt;p&gt;For at benytte sig af test og debugging i react skal man gøre følgende:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;Til at starte med skal du lave en ny mappe - mappens navn må &lt;strong&gt;ikke&lt;/strong&gt; indeholde store bokstaver. &lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Du skal sørge for at din editor (VsCode) er helt tom. Dvs. at du &lt;em&gt;kun&lt;/em&gt; skal kunne se navnet på mappen. &lt;/p&gt;&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;Når du skal til at gå i gang med dit nye react projekt skal du skrive &lt;code&gt;npx create-react-app .&lt;/code&gt; i terminalen, for at installere &lt;em&gt;react&lt;/em&gt;.&lt;br&gt;
Den skal lige installere nogle ting den skal bruge, &amp;amp; derfra burde du få 2 mapper: &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;public&lt;/li&gt;
&lt;li&gt;src&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Ryd op:
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;For at få et godt overblik over dine ting er det god idé lige at rydde op i din app.js fil, så den kommer til at se sådan ud: &lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--yf0nSapx--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/x28se1ycto8v9svoqv3n.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--yf0nSapx--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/x28se1ycto8v9svoqv3n.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Vi kan også lige fjerne vores  &lt;code&gt;app.test.js&lt;/code&gt; fra stifinderen.&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;&lt;em&gt;Hvis du gerne vil teste alt inden du starter med dine komponenter, skal du springe de to step over, men gør det senere, for ellers vil den slå ud med fejl.&lt;/em&gt; &lt;/p&gt;

&lt;h3&gt;
  
  
  Start med et simpelt komponent:
&lt;/h3&gt;

&lt;blockquote&gt;
&lt;p&gt;Her benytter vi os af en metode ved navn &lt;em&gt;TDD&lt;/em&gt; som står for &lt;em&gt;Test Driven Design&lt;/em&gt;. &lt;br&gt;
Det betyder egentlig bare at vi laver vores test først og derefter laver vores komponent. &lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Jeg har valgt at kaste mig ud i en simpel Navbar i dette tilfælde. Derfor laver vi et komponent der hedder &lt;code&gt;Navbar.js&lt;/code&gt;. &lt;em&gt;Du kan kalde dem lige hvad du vil&lt;/em&gt; &lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Det smarteste vil være at du starter ud med at skrive: 
&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--B0h8o2nD--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/9oc2xneruf2uh5khqeb0.png" alt="Alt Text"&gt;
Lige nu vil den ikke returnere noget da vi har skrevet den skal være &lt;code&gt;null&lt;/code&gt;. &lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Indsæt dit komponent i App.js:
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;Nu er det tid til at importere dit komponent:
&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--AuHycIVl--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ytmrsjudht67cxjyawcm.png" alt="Alt Text"&gt;
&lt;/li&gt;
&lt;/ol&gt;



&lt;h3&gt;
  
  
  Tilbage til dit komponent:
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;Nu skal vi oprette en mappe der i mit tilfælde kommer til at hedde &lt;code&gt;Navbar.test.js&lt;/code&gt; og her laver komponent som vi skal have en simpelt test i. &lt;br&gt;
Det kan vi gøre således: &lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--_trDkkhd--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/6svx3qrdaszswq11fmws.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--_trDkkhd--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/6svx3qrdaszswq11fmws.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Herefter skriver vi &lt;code&gt;npm test&lt;/code&gt; i terminalen for at se om  testen er &lt;code&gt;passed&lt;/code&gt;. &lt;br&gt;
Lige nu vil den returnere at der er en fejl fordi den ikke er færdig. &lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Så vi smutter lige ind og retter i vores &lt;code&gt;Navbar.js&lt;/code&gt; som lige nu returnere &lt;code&gt;null&lt;/code&gt;:&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--5oKm-VSY--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/grdri14e8jknoyl2m2oj.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--5oKm-VSY--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/grdri14e8jknoyl2m2oj.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Nu kan du prøve at køre testen igen for at se om den bliver &lt;code&gt;passed&lt;/code&gt;.&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;blockquote&gt;
&lt;p&gt;Når du tester med &lt;em&gt;Jest&lt;/em&gt; i terminalen for at se om det er noget der er  &lt;em&gt;passed&lt;/em&gt;, skal du skrive &lt;code&gt;npm test&lt;/code&gt;. &lt;br&gt;&lt;br&gt;
Her kommer der nogle valgmuligheder frem hvor du kan kan "trykke" lidt rundt og se de forskellige ting.  &lt;br&gt;&lt;br&gt;
&lt;em&gt;(For at komme ud af testen igen skal du trykke Ctrl + C i terminalen )&lt;/em&gt;&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h1&gt;
  
  
  Prettier
&lt;/h1&gt;

&lt;blockquote&gt;
&lt;p&gt;Prettier er en pakke der kan hjælpe med at formatere din kode. &lt;br&gt; Det er meget brugbart når hvis man laver et projekt med en anden person, så koden kommer til at være ens. &lt;/p&gt;
&lt;/blockquote&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;Ved at benytte prettier skal du skrive således i terminalen:  &lt;br&gt;&lt;br&gt;
&lt;code&gt;npm i -D prettier&lt;/code&gt;&lt;br&gt;
&lt;code&gt;npm i -D eslint-config-prettier&lt;/code&gt; &lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Det D vi skriver efter &lt;code&gt;npm i&lt;/code&gt; sørge for at vi får udvikler værktøjet.  &lt;/p&gt;
&lt;/blockquote&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;Du skal nu oprette 2 mapper i din stifinder der hedder:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;code&gt;prettierrc.json&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;.prettierignore&lt;/code&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Under &lt;code&gt;prettierrc.json&lt;/code&gt; kan du oprette en masse properties som prettier kan bruge til den formatering du gerne vil have.&lt;br&gt;
Dette kunne være et eksempel:&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--zOhvVyN5--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/20d2frpribzpe3wkes7x.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--zOhvVyN5--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/20d2frpribzpe3wkes7x.png" alt="Alt Text"&gt;&lt;/a&gt; &lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Pre-commit Hook til prettier:
&lt;/h3&gt;

&lt;blockquote&gt;
&lt;p&gt;Denne &lt;strong&gt;pre-commit hook&lt;/strong&gt; bruges til ikke at smide en code med "fejl" ind på f.eks. Github&lt;/p&gt;
&lt;/blockquote&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;Sørg for at da du har installert prettier at det ligger under &lt;strong&gt;devDependencies&lt;/strong&gt; inden du fortsætter.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Installer &lt;code&gt;npx mrm lint-staged&lt;/code&gt;- når den er færdig vil den lægge sig ind i &lt;code&gt;package.json&lt;/code&gt;.&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--Nhc8KiQg--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/cv5thq7x77tx20sgweaq.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--Nhc8KiQg--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/cv5thq7x77tx20sgweaq.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;For at køre &lt;em&gt;prettier&lt;/em&gt; skal vi i terminalen skrive &lt;code&gt;npm run prettier&lt;/code&gt;.&lt;br&gt;
Så kan du se i din kode at det vil blive rettet.&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Pre-commit hook
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;Installer:&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;npx husky install&lt;/code&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Lav en *pre-commit fil:&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;npx husky add .husky/pre-commit "npm test"&lt;/code&gt; &lt;em&gt;Hvis ikke den gider samarbejde med dette, skal du skrive &lt;code&gt;npx husky add.husky/pre-commit&lt;/code&gt; og derefter tilføje en linje i pre-commit filen &lt;code&gt;.husky&lt;/code&gt; mappen, der hedder &lt;code&gt;npm test&lt;/code&gt;&lt;/em&gt;.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Hvis det virker som det skal vil den automatisk lave en ny mappe i din stifinder som kommer til at hedde &lt;code&gt;husky&lt;/code&gt;, og den lader vi bare være med at røre ved.&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--gmrBuh2X--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/mhtkk05giq23wk6txfo0.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--gmrBuh2X--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/mhtkk05giq23wk6txfo0.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Når testen bliver &lt;code&gt;passed&lt;/code&gt;:
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;Lige nu vil testen kun blive &lt;em&gt;prettyfied&lt;/em&gt; men uden at blive committet.&lt;br&gt;
For at den skal kunne det skal du installere: &lt;br&gt; &lt;br&gt;
&lt;code&gt;npm i --save-dev cross-env&lt;/code&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Og derefter skal vi lige gå ind i &lt;code&gt;package.json&lt;/code&gt;for at lave en lille ændring &lt;em&gt;(der skal stå som jeg har mærket her)&lt;/em&gt; : &lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--WFjPlvd1--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/7l25uoxityxxqrqcim2b.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--WFjPlvd1--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/7l25uoxityxxqrqcim2b.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

</description>
      <category>react</category>
      <category>testing</category>
      <category>prettier</category>
    </item>
  </channel>
</rss>
