-
Set up an SSO account with two-factor authentication.
-
Run snapcraft logout
-
Run snapcraft login
-
Enter the email address.
-
Enter the password.
-
Enter the one-time password.
- Check that the log in was successful.
- 'snapcraft build' a simple snap
- sudo touch install/test-owner-file
- sudo chown nobody:nogroup install/test-owner-file
- sudo snapcraft prime
- ensure that prime/test-owner-file is owned by nobody and nogroup
snapcraft pull
a snap that hasparts
withstage-packages
.- Run
snapcraft clean
. - Verify there is cached apt data in
~/.cache/snapcraft/<hash>/
- Run
snapcraft pull
again and notice the download is minimal. - Wipe the cached apt data.
- Run
snapcraft pull
again and notice the download is as in1.
. - Run this test again, but run snapcraft on a partition separated from $HOME.
- Run
snapcraft cleanbuild --debug
for a snap. - Insert an error such that the code will fail to compile or
mistype the name of an entry in
stage-packages
. - Run
snapcraft cleanbuild --debug
again. - Ensure you are dropped into a debug shell.
- Exit the shell.
- Ensure you are dropped back into your original shell session.
- Setup a remote as described on https://linuxcontainers.org/lxd/getting-started-cli/#multiple-hosts
- Select a project to build.
- Run
snapcraft cleanbuild --remote <remote>
where<remote>
is the name you gave the remote on step 1.
-
Get the PC kernel source:
$ git clone -b pc https://git.launchpad.net/~ubuntu-kernel/ubuntu/+source/linux-snap/+git/xenial $ cd kernel
-
Run
sudo snapcraft
. -
Create a file called
pc-model.json
with the following contents:{ "type": "model", "authority-id": "$account_id", "brand-id": "$account_id", "series": "16", "model": "pc", "architecture": "amd64", "gadget": "pc", "kernel": "$kernel_snap_path", "timestamp": "$date" }
-
Replace
$account_id
with the value from https://myapps.developer.ubuntu.com/dev/account/ -
Replace
$kernel_snap_path
with the path to the snap you just created. -
Replace
$date
with the output of the commanddate -Iseconds --utc
. -
If you haven't created a key, run the following command, replacing
$key_name
with a name for your key:$ snap create-key
$key_name $ snapcraft register-key -
Sign the model:
$ cat pc-model.json | snap sign -k $key_name > pc.model
-
Install ubuntu-image:
$ sudo apt install ubuntu-image
-
Create the image:
$ sudo ubuntu-image --image-size 3G -O ubuntu-core-16 pc.model --extra-snaps $kernel_snap_path
-
Start the image in kvm:
$ kvm -smp 2 -m 1500 -netdev user,id=mynet0,hostfwd=tcp::8022-:22,hostfwd=tcp::8090-:80 -device virtio-net-pci,netdev=mynet0 -drive file=ubuntu-core-16/pc.img,format=raw
- Check that the user can be created.
- Check that it's possible to ssh into the vm.
- Check that it's possible to install a snap.
-
Download https://developer.qualcomm.com/download/db410c/linux-board-support-package-v1.2.zip
-
Extract it and copy the file
firmware.tar
to the directorydemos/96boards-kernel
. -
Run
snapcraft --target-arch arm64
in thedemos/96boards-kernel
directory. -
Create a file called
dragonboard-model.json
with the following contents:{ "type": "model", "authority-id": "$account_id", "brand-id": "$account_id", "series": "16", "model": "dragonboard", "architecture": "arm64", "gadget": "dragonboard", "kernel": "$kernel_snap_path", "timestamp": "$date" }
-
Replace
$account_id
with the value from https://myapps.developer.ubuntu.com/dev/account/ -
Replace
$kernel_snap_path
with the path to the snap you just created. -
Replace
$date
with the output of the commanddate -Iseconds --utc
. -
If you haven't created a key, run the following command, replacing
$key_name
with a name for your key:$ snap create-key
$key_name $ snapcraft register-key -
Sign the model:
$ cat dragonboard-model.json | snap sign -k $key_name > dragonboard.model
-
Install ubuntu-image:
$ sudo apt install ubuntu-image
-
Create the image:
$ sudo ubuntu-image -O ubuntu-core-16 dragonboard.model --extra-snaps $kernel_snap_path
-
Insert an sdcard into the host PC.
-
Umount the sdcard partitions.
-
Flash the image, replacing sdX with the path to the sdcard:
$ sudo dd if=ubuntu-core-16/dragonboard.img of=/dev/sdX bs=32M $ sync
-
Insert the sdcard into the dragonboard, and turn it on.
- Check that the user can be created.
- Check that it's possible to ssh into the board.
- Check that it's possible to install a snap.