Kurssilla on jaossa 60 pistettä. Pisteet jakautuvat seuraavasti

  • Viikkodeadlinet 16p
  • Koodikatselmointi 2p
  • Dokumentaatio 13p
    • Määrittely
    • Arkkitehtuuri
    • Käyttö/asennusohje
    • Testidokumentti
    • Docstring-dokumentaatio
    • Selvitys ChatGPT:n ja muiden kielimalleihin perustuvien välineiden käytöstä Huom: tämä annetaan muusta dokumentaatiosta erillään Moodlesta löytyvän lomakkeen avulla.
  • Testaus 5p
    • Testit
  • Lopullinen ohjelma 24p
    • Toiminnallisuus
    • Koodin laatu

Palautteesta on tarjolla yksi lisäpiste. Ja vielä yhden lisäpisteen voi saada suorittamalla ylimääräisen koodikatselmoinnin viikoilla 4 - 5.

Arvosanaan 1 riittää 30 pistettä, arvosanaan 5 tarvitaan noin 55 pistettä.

Läpipääsyyn vaatimuksena on lisäksi vähintään 10 pistettä lopullisesta ohjelmasta.

Lopullisesta ohjelmasta annettavat pisteet

Pisteet (yhteensä 24) jakautuvat seuraavasti

  • Käyttöliittymä 4p
    • 0p yksinkertainen tekstikäyttöliittymä
    • 1-2p monimutkainen tekstikäyttöliittymä
    • 2-3p yksinkertainen graafinen käyttöliittymä
    • 4p laaja graafinen käyttöliittymä
  • Talletetun tiedon käyttö ja tiedon tallettaminen 4p
    • ei pysyväistallennusta
    • 1-2p tiedosto (1p jos ohjelma ainoastaan lukee tiedostoja)
    • 3-4p tietokanta (3p jos ohjelma ainoastaan lukee tietokannasta dataa)
    • 3-4p internet (esim. Google Docs tai joku muu talletusratkaisu)
    • Pisteytys riippuu käsiteltävän tiedon monimutkaisuudesta
  • Sovelluslogiikan kompleksisuus 3p
  • Ohjelman laajuus 4p
  • Ulkoisten kirjastojen hyödyntäminen 1p
    • Tämän pisteen ideana on etsiä ja opetella jonkin ennestään itselle tuntemattoman kirjasto
    • Näihin eivät lukeudu materiaalissa esitellyt testaukseen, testikattavuuteen, koodin formatointiin, koodin laadun staattisen analyysiin, tai koodin dokumentointiin käytettävät kirjastot
    • Myöskään Pygamen, TkInterin tai SQLiten käyttö ei tätä pistettä tuo, eivätkä muutkaan referenssisovelluksen käyttämät kirjastot
  • Release 1p
    • Loppupalautuksesta on tehty loppupalautus-niminen GitHub-release, joka sisältää ohjelman lähdekoodin
  • Koodin laatu 4+1p
    • Kooste laatuvaatimuksista
    • 4p hyvät abstraktiot (esim. suunnittelumallien, kuten Repository-suunnittelumallin hyödynnys), selkeä tiedosto- ja hakemistorakenne, helposti testattava ja laajennettava, ei ilmeistä copypastea
    • +1p pylint-virheitä on enintään kolme
  • Virheiden käsittely 2p
    • 2p Sovellus toimii konsistentisti, ei kaadu virheellisillä syötteillä, ei heitä poikkeuksia ja antaa järkevät virheilmoitukset
  • Älä jätä sovellukseesi poiskommentoitua koodia, tai koodia jota sovellus ei käytä (esim. refaktoroinnin myötä turhaksi muuttuneet metodit, luokat, tai funktiot)
    • Jos jätät, vähenevät koodin laadun pisteet -1 tai -2p riippuen kommentoidun/turhan koodin määrästä
  • Erittäin ahkera ChatGPT:n tai vastaavien tekoälypohjaisten välineiden käyttö koodin generointiin saattaa kokonaisuudesta riippuen vähentää hieman pisteitä. (Lähtökohtaisesti tätä ei tarvitse pelätä jos suurin osa koodista ei ole generoitua.)

Laajuus ja sovelluslogiikan kompleksisuus

  • Miten laaja on laaja?
  • Kurssin referenssisovellus olisi laajuudeltaan 2 pisteen luokkaa, koska sovelluslogiikaltaan se on kohtalaisen suoraviivainen ja ansaitsisi vain yhden pisteen kompleksisuudesta
  • Laajuutta ei voida määritellä tarkasti esimerkiksi luokkien, metodien, tai funktioiden määrällä, laajuus on aina suhteellinen sovelluksen tyyppiin ja kompleksisuuteenkin
  • Eräs tapa laajentaa sovellusta ja lisätä sen kompleksisuutta on tehdä siitä parametrein konfiguroitava ja laajennettava, esimerkiksi:
    • Sovelluksen käyttämän tietokantatiedoston nimi ei ole kirjoitettu koodiin vaan on käyttäjän määriteltävissä
    • Pelissä eri vaikeustasojen pelimaailmat eivät ole määritelty koodissa vaan luodaan erillisten tiedostojen perusteella
    • Pacmanissa hirviöiden määrä ei ole ohjelmakoodiin kovakoodattu vakio vaan valittavissa käyttöliittymästä
    • Konfiguroitavuus voidaan toteuttaa joko käyttöliittymän tai konfiguraatiotiedostojen avulla

Testauksesta annettavat pisteet

Testit pitää kirjoittaa itse, niitä ei saa generoida. Täysien pisteiden (5p) edellytys:

  • Testattu kattavasti: haarautumakattavuus korkea (noin 70%)
    • Testien pitää testata hyödyllisiä asioita, pelkät testikattavuutta nostavat hyödyttömät (esim. assert-komentoja sisältämättömät) testit eivät tuo pisteitä
  • Testaus riittävää sekä yksikkö- että integraatiotasolla
    • Eli yksittäisten luokkien lisäksi on testattava myös monen luokan yhdistelmän tuottavaa toiminnallisuutta
  • Sovelluslogiikkaa testataan realistisilla skenaarioilla
  • Testit testaavat mielekkäitä asioita
    • Jos testit on tehty ainoastaan testikattavuuden kasvattamiseksi, ei pisteitä ole montaa odotettavissa
  • Riippuvuudet käsitelty järkevästi
    • Tietokantaa käyttävissä sovelluksissa testeissä käytössä “testitietokanta”. Aiheesta löytyy ohjeita mm. sovelluksen konfiguraatiot-osiossa
    • Myös valekomponentit ovat hyviä joissain tilanteissa. Niiden käytöstä on esimerkki riippuvuuksien injektointi-osiossa

Dokumentaation pisteet

Dokumentaatio tuo yhteensä maksimissaan 13 pistettä, jotka jakautuvat seuraavasti

  • Määrittelydokumentti 2p
    • Päivitetty vastaamaan lopullisen ohjelman toiminnallisuutta
    • Päivittämätön määrittelydokumentti tuo 0 pistettä
  • Arkkitehtuurikuvaus 4p
  • Käyttö/asennusohje 1p
    • Arvostelijan tulee pystyä asentamaan ohjelma ja käyttämään sitä ohjeen avulla
  • Testausdokumentti 2p
  • Docstring-dokumentaatio 2p
    • Suurin osa luokista, attribuuteista, metodeista ja funktioista on dokumentoitu docstring-kommenttien avulla
    • Luokan sisäisiä (ilmaistu nimessä _- tai __-etuliitteellä) attribuutteja, tai metodeja ei tarvitse dokumentoida
    • Testeille ei tarvitse tehdä docstring-dokumentaatiota
  • Repositorio ja README 1p
    • Repositorion ja README:n oletetaan olevan aiempien viikkojen vaatimusten mukainen
  • Selvitys ChatGPT:n ja muiden kielimalleihin perustuvien välineiden käytöstä 1p

Referenssisovellus toimii hyvänä esikuvana dokumentaation suhteen.

HUOM: älä copy-pastea referenssisovelluksen dokumentaation tekstiä omaan dokumentaatioosi, kirjoita teksti omin sanoin. Tekstin suora kopiointi johtaa hylkäämiseen.

Harjoitustyön toimivuus

  • Koneiden konfiguraatioissa on eroja, ja tällä kurssilla ei riitä että hajoitustyössä tekemäsi sovellus toimii vain omalla koneellasi
  • Harjoitustyösi pitää pystyä joka viikko suorittamaan, kääntämään ja testaamaan komentoriviltä käsin laitoksen Linux-koneilla (tai uusimmat päivitykset sisältävällä cubbli-linuxilla), muussa tapauksessa työtä ei tarkasteta ja menetät viikonpalautuksen pisteet.
  • Pääset testaamaan ohjelmaasi laitoksen koneella myös kotoa käsin käyttämällä etätyöpöytää https://helpdesk.it.helsinki.fi/ohjeet/tietokone-ja-tulostaminen/tyoasemapalvelu/etakaytettavat-tyopoydat-vdi-ja-vmware (valitse Cubbli Linux)