К основному контенту

Конфигурируем Sonar

Если использовать Sonar в реальных условиях на проекте размером чуть более среднего, использующего не один фреймворк, необходимость в конфигурировании возникает естественным образом. Ведь не все правила важны именно для вас, некоторые файлы неплохо бы и вовсе исключить, чтобы не проверялись (например, генерируемый код).

До этого времени у нас не было необходимости логиниться: вся информация итак доступна. Но, чтобы сконфигурировать систему, необходимо быть администратором. Вбиваем в форму admin/admin и после входа в систему выбираем пункт Configuration (справа вверху). Вы увидите перед собой список профилей. По умолчанию их три: Sun checks, Sonar way и Sonar way with Findbugs (отличаются они набором правил, в каждом следующем их больше). Ни один из этих профилей нельзя изменить, а только использовать в качестве шаблона. Жмите кнопку копирования и редактируйте свой профиль: можно отключить некоторые правила или изменить их приоритет. На вкладке Projects новый профиль связывается с вашим проектом.

Чтобы полностью исключить файлы и не анализировать содержайщися в них код, переходим на страницу проекта с домашней страницы и в левом меню в разделе Configuration выбираем пункт Exclusions. В текстовых полях вводим путь к файлу или маску (смотрите шпаргалку на этой же странице справа).

Если же вам понадобится для некоторых файлов отключить определенный набор проверок, выбирайте пункт Configuration, а затем в левом меню пункт General Settings и приготовьтесь осваивать особенности конфигурирования каждого инструмента (того же Checkstyle, PMD, FindBugs) в отдельности.

Вот пожалуй и все о конфигурировании.

Комментарии

Популярные сообщения из этого блога

Одно приложение, несколько баз данных

Рецепт от Spring Boot Некоторое время назад мне довелось писать агрегатор информации, разбросанной по нескольким базам данных с разными схемами. Для реализации был выбран Spring Boot. Ну, потому что модный и судя по примерам существенно упрощает жизнь за счет умной автоконфигурации. В этой статье я опишу, что же необходимо сконфигурировать и как, в случае, если вы отошли от стандартного сценария. Первым делом, необходимо прописать настройки доступа к каждой из баз. Например, вот так: Следующим шагом создадим отдельный класс конфигурации (для удобства), в котором определим dataSources: Обратите внимание, как просто получить настройки с помощью @ConfigurationProperties. Правда, пришлось ввести вспомогательный класс BaseDataSourceProperties — наследник DataSourceProperties, в котором область видимости метода getDriverClassName расширена до public. И осталось совсем немного — сконфигурировать JPA-репозитории. Насчет немного я, конечно, пошутил :) В этой части предстоит больше ...

Обработка изображений с ImageMagick

ImageMagick ( http://www.imagemagick.org ) — набор утилит для создания, редактирования, конвертирования и просмотра растровых изображений. Графический режим необходим только для просмотра. Для остальных действий над изображениями достаточно консоли. То есть налицо два отличия от привычных редакторов растровых изображений (вроде GIMP или Krita): использование набора утилит вместо одной программы для операций над изображениями не требуется GUI. Очевидно, что таким инструментом вряд ли будут пользоваться художники, фотографы или дизайнеры. Чтобы разобраться для кого предназначен этот набор, предлагаю ознакомиться с предоставляемыми возможностями. Что умеет ImageMagick? Чтобы ответить на поставленный вопрос я перечислю входящие в набор утилиты, напишу какой функционал предоставляет каждая из них и, конечно же, приведу примеры использования. identify — информационная утилита, воспользовавшись которой можно узнать формат изображения и множество других его свойств (например, высоту,...

Изучение Qt маленькими порциями. Разбираем ваше первое приложение

Прошлый раз вы установили QtCreator, а затем сгенерировали ваше первое приложение. Всё сработало и у вас теперь есть собственное пустое окно QMainWindow на экране. Всё хорошо, но что же действительно было сделано? Давайте пройдёмся по сгенерированному коду, чтобы стало понятно, что же случилось на самом деле. Приложение состоит из одного класса и функции main, необходимой для запуска. Давайте посмотрим на эту функцию main.cpp #include <QtGui/QApplication> #include "mainwindow.h" int main(int argc, char *argv[]) { QApplication a(argc, argv); MainWindow w; w.show(); return a.exec(); } В этой функции создаётся экземпляр класса QApplication . Каждому приложению Qt нужен один и только один экземпляр класса QApplication. Он представляет собой само приложение и содержит главный цикл обработки событий. Вы можете спросить, что такое цикл обработки событий? Это просто цикл, ожидающий наступления события. Например, нажатие клавишы, перемещение мышки, сетевые пакеты, событ...