Odata cu Windows 8 si aplicatiile de tip Metro App, lucrurile au inceput sa se schimbe nu doar cum o aplicatie trebuie sa se comporte, sa arate si sa reactioneze ci si cum facem deploy-ul.
Astazi vreau sa vorbim cum putem sa generam un pachet (setup package) pentru aplicatia noastra pentru a putea sa fie instalata m-ai tarziu pe o masina cu Windows 8.
Necesitatea creari unui pachet apare destul de usor. Clientul ne poate cere intr-un anumit moment sa ii trimitem aplicatie pentru a vedea cum arata si cum functioneaza sau echipa de testare are nevoie de aplicatie pentru testare.
Pentru oricare din aceste cazuri, un zip cu codul sursa nu este o solutie. Persoanele la care ajunge acest zip s-ar putea sa nu fie tehnice si nici nu vrei sa trimiti codul sursa la orice persoana. Output-ul generat in bin nu o sa ajute deloc.
Microsoft ne ofera o solutie la aceasta problema - crearea unui pachet a aplicatiei noastre. Odata creat acesta poate sa fie instalat pe orice masina cu Windows 8.
Dupa ce am creat aplicatia, este necesar sa selectam proiectul principal (cel pe care il folosim sa rulam aplicatia), iar din meniul care se afiseaza cand dam click dreapta pe acesta sa selecta "Store -> Create App Package" (la acesta optiune se poate ajunge si din meniu "Project -> Store -> Create App Package").
Dupa acest pas aveti doua optiuni, sa creati un pachet pentru store-ul de Windows 8 sau un pachet care sa fie folosit local. In cazul nostru, avem nevoie de a doua optiune. In acest moment este bine de mentionat ca acest pachet poate sa fie instalat doar pe sistemele de operare cu Windows 8 Enterprise sau cele care au o licenta pentru dezvoltare.
In urmatorul pas o sa fie necesar sa introducem locatie unde se v-a genera pachetul, versiunea aplicatiei si pentru ce platforme vrem sa cream pachetul (x86, x64, ARM, any CPU). La acest pas mi-a placut functionalitatea de auto-increment la versiunea aplicatiei. Ne poate salva de cateba batai de cap.
Odata datele introduse pachetul se poate crea apasant butonul "Create", cand pachetul se genereaza automat. Pachetul odata generat o sa contina un fiser bat cu numele "Add-AppxDevPackage.bat" care poate sa fie rulat pe orice masina atat din linie de comanda cat si separat. Singurul lucru care trebuie facut la instalarea pachetului este sa rulam acest bat ca si administrator (cu drepturi elevate). Procesul de creare si deploy a unui pachet este destul de simplu, poate sa fie inclus si intr-un build automat a unui MSBUILD si este tot de ce am avea nevoie pentru un deploy simplu intr-un mediu de testare sau un demo pentru client.
Dupa acest pas aveti doua optiuni, sa creati un pachet pentru store-ul de Windows 8 sau un pachet care sa fie folosit local. In cazul nostru, avem nevoie de a doua optiune. In acest moment este bine de mentionat ca acest pachet poate sa fie instalat doar pe sistemele de operare cu Windows 8 Enterprise sau cele care au o licenta pentru dezvoltare.
In urmatorul pas o sa fie necesar sa introducem locatie unde se v-a genera pachetul, versiunea aplicatiei si pentru ce platforme vrem sa cream pachetul (x86, x64, ARM, any CPU). La acest pas mi-a placut functionalitatea de auto-increment la versiunea aplicatiei. Ne poate salva de cateba batai de cap.
Odata datele introduse pachetul se poate crea apasant butonul "Create", cand pachetul se genereaza automat. Pachetul odata generat o sa contina un fiser bat cu numele "Add-AppxDevPackage.bat" care poate sa fie rulat pe orice masina atat din linie de comanda cat si separat. Singurul lucru care trebuie facut la instalarea pachetului este sa rulam acest bat ca si administrator (cu drepturi elevate). Procesul de creare si deploy a unui pachet este destul de simplu, poate sa fie inclus si intr-un build automat a unui MSBUILD si este tot de ce am avea nevoie pentru un deploy simplu intr-un mediu de testare sau un demo pentru client.
O aplicatie pentru care pana acum era sudicient XCopy-deployment, care ar fi motivul tehnic pentru care daca o rescriu pentru Metro/WinRT as avea nevoie de un installer cand o instalez direct local? Doar necesitatea de a face un deployment centralizat prin AD?
ReplyDeleteO aplicatie Metro App, este special creata pentru tablete si dispozitive mobile. O tableta cu W8, nu o sa contina niciodata Windows Services sau aplicatii desktop clasice.
DeleteMetro App o sa fie distribuite prin Store (asemanator cu Markerplace pentru WP7), iar instalarea acestora cu un kit de installer nu o sa poata sa fie facuta in general (exceptie Windows 8 Enterprise si vs de development).
Deployment-ul asemanator cu cel cunoscut prin AD o sa poata sa fie facut doar in cazul in care exista Windows 8 Enterprise.
Pentru aplicatiile desktop clasice, pe Windows 8 nu s-a schimbat nimica, dar acestea nu o sa ruleze pe tablete, unde varianta RT o sa fie instalata.
Stiu despre cele doua variante de deployment de la WinRT/Metro si de obligativitatea distributiei prin Marketplace - deci normal ca ma refeream la distributia in cadrul unui domeniu, care va fi o varianta foarte raspandita in cadrul firmelor care nu vor dori sa ca MS sa-si bage nasul in aplicatiile interne - pentru acest scenariu ar fi interesant mecanismul care ne va impiedeca fizic sa fac XCopy in locatia potrivita ;) daca am drepturi de admin pe statia locala cu Win8 (nu ma refer la tablete si mobile). Ca sunt ca si acuma avantaje la distributia centralizata prinAD, e alta poveste.
DeleteMa tem ca motivatia pentru care in WinRT au reintrodus necesitatea unui installer se gaseste aici: http://www.winsupersite.com/blog/supersite-blog-39/windows8/windows-8-registry-140910
Delete- registry shows it's ugly head again, like in COM days.. :)
Asta, si probabil faptul ca o aplicatie Metro in Win8 nu se va putea lansa din command-line, la fel ca pe Windows Phone, deci cumva va trebui adaugat un tile in start screen pentru a o lansa, in lipsa altei alternative.