Skip to content

Latest commit

 

History

History
362 lines (273 loc) · 11.9 KB

README.md

File metadata and controls

362 lines (273 loc) · 11.9 KB

Dokumentáció

##Koktél receptek Készítette: Peknyó Szilvia

###1. Követelményanalízis #####1.1. Célkitűzés, projektindító dokumentum A program legfőbb célja jól átláthatóan, és érthetően megjeleníteni az adott koktélok, és italok főbb tulajdonságait, és receptjüket egy webes vastagkliens, azaz egyoldali alkalmazás felhasználásával Az adatok védelme érdekében legyen lehetőség regisztrációra, majd bejelentkezésre. Bejelentkezett felhasználó a koktélok listáját megtekintheti, bővítheti, meglévő elemeket törölhet, valamit megjegyzéseket írhat.

######Funkcionális követelmények:

  • Regisztrációra
  • Bejelentkezés
  • Csak bejelentkezett felhasználók által elérhető funkciók
    • új ital felvételére a listába
    • a meglévő italok szerkesztésére
    • a meglévő italok törlésére
    • komment írása

######Nem funkcionális követelmények:

  • Könnyű áttekinthetőség: Színekkel típus szerint csoportosítás
  • Használhatóság: Könnyű áttekinthetőség, ésszerű elrendezés, könnyen kezelhetőség
  • Megbízhatóság: jelszóval védett funkciók, és a jelszavak védelme a háttérben. Hibásan bevitt adatok esetén a program jól láthatóan jelezzen a felhasználónak, és emelje ki a hibás beviteli mezőket. A jól bevitt adatok maradjanak az űrlapban.
  • Karbantarthatóság: könnyen lehessen bővíteni, a különböző típusú fájlok külön csoportosítva, ésszerűen legyenek felbontva, a könnyebb fejleszthetőség miatt

#####1.2. Szakterületi fogalomjegyzék

Fajták:

  • Shot: Felespohárban felszolgált, gyakran csak alkoholt tartalmazó ital.
  • Cocktail: Koktélos pohárban, szirupokkal, gyömülcslevekkel készített ital.
  • Long drink: Egyszerű long-os pohárban felszolgált ital, gyakran egy fajta alkoholt és üdítőt tartalmaz.
  • Aperitif: Étkezések előtt, étvágy fokozás céljából fogyasztott ital.

Alap ital: A koktélban legnagyobb arányban részt vevő tömény alkohol.

#####1.3. Használatieset-modell, funkcionális követelmények

Vendég: Csak a publikus oldalakat éri el

  • Főoldal
  • Bejelentkezés
  • Regisztráció

Bejelentkezett felhasználó: A publikus oldalak elérésén felül egyéb funkciókhoz is hozzáfér.

  • Új recept felvétele
  • Meglévő recept megtekintése
  • Meglévő recept szerkesztése
  • Meglévő recept törlése
  • Komment írása

Vegyünk példának egy egyszerű folyamatot:

Meglévő recept szerkesztése:

  1. A felhasználó az oldalra érkezve, bejelentkezik vagy regisztrál
  2. Regisztráció után megtekintheti a recepteket listázó oldalt, ahol kiválaszthatja a szerkeszteni kívánt receptet.
  3. Megnyomja a „Megtekintés” feliratú gombot
  4. A megtekintés oldalon kiválaszthatja a „Szerkesztés” gombot
  5. Szerkesztés oldalon felviszi az új adatokat
  6. Submit gombra kattintva elmenti a változásokat

###2. Tervezés

#####2.1. Architektúra terv

######2.1.1. Komponensdiagram

######2.1.2. Oldaltérkép:

Publikus:

  • Főoldal
  • Bejelentkezés
  • Regisztráció

Bejelentkezett:

  • Főoldal
  • Új koktél felvétele
  • Listaoldal
    • Koktél törlése
    • Koktél megtekintése
      • Koktél szerkesztése
      • Komment hozzáfűzése

######2.1.3. Végpontok

  • GET/: főoldal
  • GET/login: bejelentkező oldal
  • POST/login: bejelentkező adatok felküldése
  • GET/login/signup: regisztrációs oldal
  • POST/login/signup: regisztrációs adatok felküldése
  • GET/logout: kijelentkező oldal
  • GET/recipes/list: koktéllista oldal
  • GET/recipes/new: új koktél felvétele
  • POST/recipes/new: új koktél felvételéhez szükséges adatok felküldése
  • GET/recipes/id: koktél adatok
  • POST/recipes/id: új megjegyzés felvitele
  • GET/recipes/delete=id: koktél recept törlése
  • GET/recipes/edit=id: koktél módosítása
  • POST/recipes/edit=id: koktél módosítása, adatok felküldése

#####2.2. Felhasználói-felület modell

######2.2.1.Oldalvázlatok: Főoldal

Regisztrációs oldal

Bejelentkező oldal

Koktél listaoldal

Új koktél felvétele

Koktél megtekintése

Koktél szerkesztése

######2.2.2.Designtervek (végső megvalósítás kinézete):

Főoldal

Regisztrációs oldal

Bejelentkező oldal

Koktél listaoldal

Új koktél felvétele

Koktél megtekintése

######2.2.3. Osztálymodell

Adatmodell

Adatbázisterv

######2.2.4. Dinamikus működés

Szekvenciadiagram

Vegyünk példának a regisztrációt, majd egy új elem felvételét, szerkesztését, törlését, mindezt szekvenciadiagrammon.

###3. Implementáció

######3.1.1. Fejlesztőkörnyezet

Webes IDE: Cloud9

  • Github account szükséges
  • Belépés után új workspace létrehozása (node.js)
  • Ezután elkezdhetjük a kód írását
  • git add paranccsal kiválaszthatunk egy fájlt verzionálásra, vagy git add . paranccsal az összes fájlt kiválaszthatjuk
  • git commit -m "commit" paranccsal feltehetjük a fájlokat a cloud9 helyi tárolójába. Az így megjelölt verziókhoz a későbbiekben visszatérhetünk, különbségüket megtekinthetjük.
  • git push origin master paranccsal a lokális tárolóból feltölthetjük a tartalmat a Github-ra.
  • Végezetül a Github oldalán leellenőrizhetjük a munkánkat.

######3.1.2. Könyvtárstruktúra, funkciók

  • ckd193-beadando1
    • config
      • waterline.js
    • controllers
      • index.js
      • recipes.js
      • login.js
    • models
      • comment.js
      • recipes.js
      • recipes.test.js
      • user.js
      • user.test.js
    • views: handlebars (hbs) fájlok
      • login
        • index.hbs
        • signup.hbs
      • recipes
        • edit.hbs
        • list.hbs
        • new.hbs
        • show.hbs
      • index.hbs
      • layout.hbs
    • bower.json
    • package.json
    • server.js

###4. Tesztelés #####4.1. Tesztelési környezetek Kétféle tesztelési módszert használunk a program teljeskörű tesztelésére. Először egységteszteket végzünk a mocha keretrendszer és a chai ellenőrző könyvtár segítségével. Egységtesztelés közben a modellek működését, a problémamentes funkciókat és műveleteket ellenőrizzük. Másodszor a funkciónális teszetelés segítségével a végpontokat ellenőrizzük, a megfelelő tartalom megjelenését, és az oldalak működőképességét. #####4.2. Egységteszt

Kiválasztjuk a tesztelni kívánt modelt (ezesetben a user modelt), és létrehozunk hozzá egy tesztelő fájlt. Legyen ez most a: user.test.js

Hozzuk létre az abstract modellréteget (ORM), majd vegyük sorra a teszteseteket.

Regisztráció tesztelése: user létrehozása

    it('should be able to create a user', function () {
        return User.create(getUserData())
        .then(function (user) {
            expect(user.felhnev).to.equal('abcdef');
            expect(bcrypt.compareSync('jelszo', user.password)).to.be.true;
            expect(user.surname).to.equal('Gipsz');
            expect(user.forename).to.equal('Jakab');
            expect(user.avatar).to.equal('');
        });
    });

Jelszó ellenőrzése, helyes és hibás jelszó esetén

    describe('#validPassword', function() {
        it('should return true with right password', function() {
             return User.create(getUserData()).then(function(user) {
                 expect(user.validPassword('jelszo')).to.be.true;
             })
        });
        it('should return false with wrong password', function() {
             return User.create(getUserData()).then(function(user) {
                 expect(user.validPassword('titkos')).to.be.false;
             })
        });
    });

#####4.3. Funkciónális teszetelés

Válasszuk ki a tesztelni kívánt modelt (ezesetben recipes), és hozzuk létre hozzá a tesztelő fájlt. Nevezzük el: recipes.test.js

Teszteljük sorban az egyes végpontok működését. Vegyünk most példának egy végpontot, és egy funkció működését:

Új recept oldal elérése:

    it('should go the recipe page', function () {
        return browser.visit('/recipes/new')
        .then(function () {
            browser.assert.success();
            browser.assert.text('div.page-header > h1', 'Új recept felvétele');
        });
    });

Sikeres bejelentkezés a megfelelő adatokkal:

    it('should be able to login with correct credentials', function (done) {
        browser
            .fill('felhnev', 'Ellasandra')
            .fill('password', 'titkos')
            .pressButton('button[type=submit]')
            .then(function () {
                browser.assert.redirected();
                browser.assert.success();
                browser.assert.url({ pathname: '/recipes/list' });
                done();
            });
    });

A tesztfájl lefuttatásához használt parancs: npm test

Sikeres tesztek lefutása után az alábbi üzenetet kell kapjuk:

pessaai:~/workspace/ckd193-beadando1 (master) $ npm test

> @ test /home/ubuntu/workspace/ckd193-beadando1
> node_modules/mocha/bin/mocha **/*.test.js



  User visits index page
    ✓ should be successful
    ✓ should see welcome page

  User visits new recipe page
    ✓ should go to the authentication page
    ✓ should be able to login with correct credentials (1706ms)
    ✓ should go the recipe page (154ms)

  UserModel
    ✓ should work
    ✓ should be able to create a user (536ms)
    ✓ should be able to find a user (514ms)
    ✓ should be able to update a user (524ms)
    #validPassword
      ✓ should return true with right password (493ms)
      ✓ should return false with wrong password (486ms)


  11 passing (5s)

#####4.4.Tesztesetek

  • User
    • Felhasználó létrehozása
    • Felhasználó keresése
    • Felhasználó módosítása
    • Bejelentkezés jó, és rossz jelszóval
  • Recipe
    • Főoldal láthatósága
    • Új recept felvétele oldal láthatósága
    • Csak bejelentkezett felhasználó által látható oldal láthatósága
    • Sikeres bejelentkezés

###5. Felhasználói dokumentáció

Futtatáshoz szükséges operációs rendszer: Tetszőleges operációs rendszer

A futtatáshoz szükséges hardver: Operációs rendszerek szerint megadva

Egyéb követelmények: Internet böngésző telepítése, JavaScript ajánlott

Program használata:

  1. Böngészőben nyissuk meg a főoldalt
  2. Jobb felső sarokban kattintsunk a Bejelentkezés feliratra
  3. Bejelentkezés/Regisztráció után a Lista oldalra jutunk
  4. Bal alsó sarokban az Új recept felvitele gombra kattintva tudunk új recepteket felvenni a listába
  5. Töltsük ki az űrlapot
  6. Hibás adatok esetén az űrlap jelezni fogja a hibát
  7. Submit gombra kattintva mentsük el az adatokat
  8. Lista oldalon: Törlés gombra kattintva törölhetjük a receptet
  9. Lista oldalon: Megtekint gombra kattintva a megtekintés oldalra jutunk
  10. Megtekintés oldalon található a szerkesztés gomb, és a komment írása funkció
  11. Szerkesztés oldal: megegyezik az új recept felvitel funkcióval, csak előre láthatóak benne a recept eddigi adatai

###6. Irodalomjegyzék:

http://webprogramozas.inf.elte.hu/alkfejl.php

http://ade.web.elte.hu/wabp/lecke2_lap1.html

http://webprogramozas.inf.elte.hu/alkfejl/A_dokumentacio_felepitese.pdf