Функции расширения
Расширение автоматически обнаруживает в открытом рабочем пространстве проект KasperskyOS и запускается. Параметр обнаружения – наличие в рабочем пространстве файла .vscode/kos_project.json
или директории einit
. Если расширение автоматически не активировалось в директории, но вы уверены, что это проект KasperskyOS, то выполните команду KOS: Activate extension in this directory
. Команда активирует расширение и создает в директории проекта пустой файл .vscode/kos_project.json
. Чтобы отменить ручную активацию, удалите этот файл.
После запуска расширение добавляет на нижнюю панель редактора кода Visual Studio Code следующие кнопки:
– выбор цели сборки;
– запуск проекта в QEMU;
– запуск выбранной цели с отладкой;
– сборка всех целей;
– сборка выбранной цели;
– очистка директории сборки;
– переключение типа сборки;
– включение/отключение сборки проекта с тестами;
– выбор целевой платформы для сборки;
– выбор устройства или эмулятора QEMU;
– отображение версии SDK.
Функции, которые предоставляют кнопки, также можно вызвать из командной строки редактора кода, открываемой по нажатию на клавишу F1. Все команды имеют префикс KOS:
.
Работа с базовым образом KasperskyOS
Расширение позволяет не выполнять полную сборку решения на базе KasperskyOS после внесения изменений в код прикладной программы, а вместо этого использовать следующий сценарий:
- Запуск в эмуляторе QEMU базового образа решения на базе KasperskyOS, входящего в состав SDK. В базовом образе содержатся все системные программы, необходимые для запуска и отладки программ, упакованных в KPA-пакеты.
- Сборка прикладной программы и ее упаковка в KPA-пакет. Для того чтобы упаковать прикладную программу в KPA-пакет, необходимо использовать
CMake
-команды библиотеки kpa. - Установка программы из KPA-пакета в запущенный на шаге 1 образ решения и ее запуск под управлением KasperskyOS.
- Внесение изменений в код прикладной программы.
- Повторение шагов 2-5.
- Расширение также позволяет отлаживать программу, запущенную в базовом образе KasperskyOS. Подробнее см. "Отладка программ в составе KPA-пакета".
Создание базового описания политики безопасности решения
Расширение позволяет автоматически создавать простейшие описания политики безопасности решения для проекта.
Чтобы создать базовое описание политики безопасности:
- Убедитесь, что расширение KasperskyOS SDK Extension установлено и активно.
- Нажмите на клавишу F1.
- Выполните команду
KOS: Generate policy file for current project
. - Выберите тип базового описания политики, который вы хотите создать:
Grant all permissions
- создать простейшее описание политики безопасности решения, которая разрешает любые взаимодействия процессов любых классов между собой и с ядром KasperskyOS, а также разрешает любому процессу инициализировать запуск процессов.Grant necessary permissions
- создать простейшее описание политики безопасности решения, которая разрешает любые взаимодействия процессов любых классов между собой и с ядром KasperskyOS, а также определяет необходимые разрешения для инициализации запуска процессов на основе файла init.yaml.in в составе проекта.
- Введите имя файла для сохранения созданного описания политики безопасности.
Эти политики можно использовать только в качестве заглушек на ранних стадиях разработки решения на базе KasperskyOS, чтобы модуль безопасности Kaspersky Security Module "не мешал" взаимодействиям. В реальном решении на базе KasperskyOS применять такие политики недопустимо.
Запуск тестов
После активации расширения на боковой панели Visual Studio Code появляется вкладка Testing – . При выборе вкладки Testing в окне редактора кода отобразится дерево тестов, созданных с помощью библиотеки Google Test и обнаруженных в файлах директории
test/
.
Для запуска тестов нажмите на кнопку . По умолчанию запускаются все обнаруженные тесты, но вы можете выбирать определенные тесты на вкладках с исходным кодом тестов или определенные группы тестов, выбирая их из дерева всех тестов. Запускать можно только тесты, которые добавлены в файлы
CMakeLists.txt
для сборки программ с помощью CMake
-команд kl_kos_add_small_test()
или generate_kos_test()
из CMake
-библиотеки TestGenerator, поставляемой в составе SDK.
Результаты работы тестов, а также файлы журналов находятся в директории <директория_сборки>/bin/tests/output
.
Запуск тестов политик безопасности решения
Расширение позволяет запускать тесты политики безопасности решения для проекта, созданные на основе описания политики безопасности решения.
Чтобы собрать и выполнить тесты политики безопасности решения:
- Убедитесь, что описание политики безопасности решения содержит тесты политики безопасности решения.
- Убедитесь, что
CMake
-команды сборки тестов политики безопасности решения добавлены в один из файловCMakeLists.txt
проекта. - Убедитесь, что расширение KasperskyOS SDK Extension установлено и активно.
- Выполните сборку всех целей, нажав на кнопку
на нижней панели.
- Нажмите на кнопку
выбора цели сборки и выберите цель с именем
kos-qemu-image-PalTest<N>-sim
, где N – индекс PSL-файла в списке PSL-файлов, содержащих тесты политики безопасности решения. - Нажмите на кнопку сборки выбранной цели
.