Inimestel on raske näha probleemi suurt pilti, ilma et nad pühendaksid sellele palju aega ja vaeva. See juhtub eriti suurte ja keeruliste rakendustega töötades. Millised on minu muudatuste kõrvalmõjud? Miks mõjutab see rida siin koodibaasi kaugema osa teste? Täiuslikku või täielikku lahendust ei ole olemas, kuid Shopify tuli välja tööriistaga, mis tõenäoliselt aitab teid ja teie meeskonda.
Sissejuhatus
Selleks, et rääkida Packwerk, peame kõigepealt tutvustama mõned mõisted.
- Ühtekuuluvus: viitab sellele, kui palju mooduli või klassi elemendid kokku kuuluvad.
- Haakeseadeldis: viitab moodulite või klasside vahelise sõltuvuse tasemele.
- Piirid: viitab tõketele, mis esinevad kood. Sellisel juhul viitab koodipiir eri valdkondadele sama koodibaasi sees.
- Modulariseerimine: protsess, mille käigus jagatakse tarkvarasüsteem mitmeks eraldi mooduliks, kus iga moodul töötab iseseisvalt.
Probleemid
Nagu me teame, Ruby ei paku head lahendust koodide piiride jõustamiseks. Me võime määrata nähtavuse, kuid kõik sõltuvused laaditakse globaalsesse nimeruumi. Suurtes või monoliitrakendustes tekitab selline piiride puudumine järgmised probleemid.
- Vähene ühtekuuluvus,
- Kõrge haakeseadeldis,
- Spagetikood.
Püüdes Shopify monoliiti moduleerida ja piire kehtestada, proovisid nad erinevaid lahendusi, saavutamata oodatud tulemusi:
- Privaatsete konstantide seadistamine,
- Piiride kehtestamine läbi kalliskivide,
- Testide kasutamine komponentide vaheliste seoste vältimiseks,
- Kasutades Ruby's Modulation gem,
- Mikroteenuste loomine.
Võttes arvesse kõiki varasematest katsetest saadud teadmisi, otsustasid nad luua omaenda tööriista: Packwerk.
Packwerk
Mis on Packwerk?
Packwerk on staatilise analüüsi vahend, mida kasutatakse piiride kehtestamiseks rühmade vaheliste Ruby failid nimega paketid.
Mis on pakett?
A pakett on kaust, mis sisaldab autoloaded koodi. Shopify meeskond julgustab kasutama pakettide loomisel parimaid projekteerimistavasid.
- Me peaksime pakkima kokku asju, millel on kõrge funktsionaalne ühtekuuluvus,
- Paketid peaksid olema omavahel suhteliselt lõdvalt seotud.
Piirikontrolli liigid
Me saame kehtestada privaatsuse ja sõltuvuse piirid, kontrollida piiride rikkumisi ja tsüklilisi sõltuvusi.
Packwerk praktikasse
Pakettide loomisel ei ole ühte kindlat viisi, kuidas oma rakendust struktureerida või ümber struktureerida. Selles artiklis järgime lähenemisviisi, mida soovitab
Stephan Hagemann aastal Ruby on Rails järkjärguline modulatsioon.
Valige projekt
Saate luua uue projekt või valige üks oma projektidest. Otsustasin kasutada avatud lähtekoodiga projekti nimega CodeTriage. Oluline on mainida, et me vajame Rails 6 rakendust, kuna Packwerk kasutab Zeitwerki.
Packwerki initsialiseerimine
Kõigepealt peame lisama gemi meie Gemfile'ile nagu kalliskivi 'packwerk'
ja seejärel käivitage kimp
konsoolis. Siis oleme valmis initsialiseerida pärl töötab packwerk init
.
Pärast seda märkame, et Packwerk genereeris meile kolm faili:
-
packwerk.yml
-
package.yml
-
inflections.yml
packwerk.yml on konfiguratsioonifaili Packwerk kus me määratleme kaasatud ja välistatud failid, loetleme laadimisrajad, määratleme muuhulgas ka inflections faili;
package.yml on paketi konfiguratsioonifail. Selles failis lisame meie paketi piiride konfiguratsiooni. Iga kausta, mille package.yml on olemas, tunnistab paketiks Packwerk. See on kõik, Packwerk lõime meie esimese
pakett ja me nimetame seda juur pakett.
inflections.yml on koht, kuhu me paigutame oma kohandatud käänded ja akronüümid, kui me neid kasutame.
Lisateavet failide ja nende konfiguratsiooni kohta leiate aadressilt
Packwerk.
Packwerk omadused
Modulariseerimise toimimiseks on vaja kolme põhiomadust: nimega konteiner, selle sisuja selgesõnaline sõltuvused muudel konteinerid. Nii et defineerime need omadused Packwerk:
-
Nimi: Paketi nimi on selle suhteline tee juurtelt
rakendus.
-
Sisu: Kui me paigutame pakett.yml-i kausta, on kõik selles kaustas olevad failid nüüd paketi sisu.
-
Sõltuvused: Me võime määratleda sõltuvused teistest pakettidest, lisades sõltuvuste võtme võtme package.yml.
Teine fail, mis ei ole vaikimisi lisatud, kuid on soovitatav, on README. See on oluline, et anda teavet paketi kasutamise kohta.
I episoodi lõpp

Loe edasi
GraphQL Ruby. Kuidas on tulemuslikkus?
Rööpad ja muud transpordivahendid
Railsi arendamine TMUX, Vim, Fzf + Ripgrep abil