Новости Joomla

Как тестировать Joomla PHP-разработчику? Компонент Patch tester.

👩‍💻 Как тестировать Joomla PHP-разработчику? Компонент Patch tester.Joomla - open source PHP-фреймворк с готовой админкой. Его основная разработка ведётся на GitHub. Для того, чтобы международному сообществу разработчиков было удобнее тестировать Pull Requests был создан компонент Patch Tester, который позволяет "накатить" на текущую установку Joomla именно те изменения, которые необходимо протестировать. На стороне инфраструктуры Joomla для каждого PR собираются готовые пакеты, в которых находится ядро + предложенные изменения. В каждом PR обычно находятся инструкции по тестированию: куда зайти, что нажать, ожидаемый результат. Тестировщики могут предположить дополнительные сценарии, исходя из своего опыта и найти баги, о которых сообщить разработчику. Или не найти, и тогда улучшение или исправление ошибки быстрее войдёт в ядро Joomla. Напомню, что для того, чтобы PR вошёл в ядро Joomla нужны минимум 2 положительных теста от 2 участников сообщества, кроме автора. Видео на YouTubeВидео на VK ВидеоВидео на RuTubeКомпонент на GitHub https://github.com/joomla-extensions/patchtester@joomlafeed#joomla #php #webdev #community

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6.2PageBuilder Toolkit - это специализированный плагин для конструктора страниц Yootheme Pro, содержит набор различных утилит для ускорения процесса работы и отладки макета, множественные улучшения в интерфейсе, включая поддержку dark mode, подсказки, быстрая смена разрешения в окне просмотра и много чего еще.v.1.6.2 Что нового?- Индикатор статусов: теперь не просто показывает состояние запросов, но и делает автоматические попытки их отправки при кратковременных сбоях в сети, а если это не помогло, то переводит конструктор в ручной режим, что позволяет сохранит макет и настройки темы прежде чем вы потеряете все, что было сделано с момента последнего сохранения- Подсветка ошибок в макете: плагин анализирует код страницы и может автоматически подсвечивать data атрибуты с кучей мусора, которые попадают в код страницы при копипасте из Figma в TinyMCE (пригодится для старых макетов, в текущей работе плагин сам очищает код мусора). Также есть подсветка семантических ошибок сборки - дубли h1 тега на странице и вложенных друг в друга заголовков.- Улучшена поддержка будущего релиза Yootheme Pro 5 и редактора CodeMirror 6Плагин для русскоязычных пользователей доступен в каталоге расширений SovMart и распространяется за символическую плату (100р). Разработчики Joomla расширений и партнеры автора могут получить плагин бесплатно.Для работы плагина необходим конструктор страниц Yootheme Pro.Разработчик плагина - участник нашего сообщества Александр Судьбинов (@alexrevo), член официальной группы поддержки Yootheme Pro. Страница расширенияОписание на сайте автора@joomlafeed#joomla #yootheme

0 Пользователей и 1 Гость просматривают эту тему.
  • 9 Ответов
  • 1146 Просмотров
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Оптимизировать запрос
« : 17.01.2015, 03:10:52 »
Есть вот такая конструкция:
Код: php
        foreach ($list as $item) {

          $query = $db->getQuery(true);
          $query->select('field')
            ->from('#__table')
            ->where('id='.(int)$item);
          $result_item = $db->setQuery($query)->loadObject();

          $result_item->field = (int)$result_item->field + 1;

          $query = $db->getQuery(true);
          $query->update('#__table')
            ->set('field='.(int)$result_item->field)
            ->where('id='.(int)$item);
          $db->setQuery($query)->execute();

        }

$list - одномерный массив, в $item всегда число
Как-либо можно это оптимизировать?
« Последнее редактирование: 17.01.2015, 03:21:08 от AlekVolsk »
*

voland

  • Легенда
  • 11026
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Оптимизировать запрос
« Ответ #2 : 17.01.2015, 03:52:56 »
Код: php
        $query = $db->getQuery(true);
        $query->select('id, field')
          ->from('#__table')
          ->where('id in ("'.implode(',', $list).'")';
        $result_item = $db->setQuery($query)->loadObjectList();
 
        foreach ($result_item as $item) {
 
          $item->field = (int)$item->field + 1;
 
          $query = $db->getQuery(true);
          $query->update('#__table')
            ->set('field='.(int)$item->field)
            ->where('id='.(int)$item->id);
          $db->setQuery($query)->execute();
 
        }

Я правильно понял?

Думал, что как-то можно селект внутрь ->update('#__table')->set() запихать, не соображу как, давно сложными запросами не баловался уже =)
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
Re: Оптимизировать запрос
« Ответ #3 : 17.01.2015, 03:54:16 »
просто
Код: php
if(count($list)){
     $query->update('#__table')
            ->set('`field`=`field`+1')
            ->where('id IN('.implode(',', $list).')');
     $db->setQuery($query)->execute();
}
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Оптимизировать запрос
« Ответ #4 : 17.01.2015, 03:57:50 »
ух ты! делфи такого точно не позволяет!
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
Re: Оптимизировать запрос
« Ответ #5 : 17.01.2015, 03:58:42 »
ух ты! делфи такого точно не позволяет!
Эт не делфи ) Это MySQL так позволяет )
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Оптимизировать запрос
« Ответ #6 : 17.01.2015, 04:06:15 »
Ну, ту же конструкция запроса еще и php обрабатывается.
Интербейз (штатно для десктопа обычно на нем пишу) такой запрос тоже кушает, но делфийский компилятор попытку выполнения такого запроса, если он не прямой строкой а через объект, отбрасывает, а именно руганется на set('`field`=`field`+1'). А если еще и кроссплатформенный проект, то и where() тоже откинет - ему туда только либро строку либо готовую переменную пихай.

Да, веб куда продвинутей десктопных ооп ;)



Я же таким образом могу в set() несколько полей указать?
->set('field1=field1+1, field2=field2-1')
« Последнее редактирование: 17.01.2015, 04:13:17 от AlekVolsk »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Оптимизировать запрос
« Ответ #7 : 17.01.2015, 04:17:47 »
Есть еще вот такой г-код:
Спойлер
[свернуть]

С этим что-то можно сделать?
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
Re: Оптимизировать запрос
« Ответ #8 : 17.01.2015, 11:57:39 »
Ну, ту же конструкция запроса еще и php обрабатывается.
PHP обрабатывает только результат запроса! Конструкция обычная строка UPDATE table SET field=field+1 WHERE id=1 которая направляется в SQL и получается результат выполнения запроса!


Да, веб куда продвинутей десктопных ооп ;)
Вы не видели C# или Java значит!


Я же таким образом могу в set() несколько полей указать?
->set('field1=field1+1, field2=field2-1')
Да
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Оптимизировать запрос
« Ответ #9 : 17.01.2015, 13:00:43 »
С этим что-то можно сделать?
Я бы сократил немного:
Спойлер
[свернуть]
Не будь паразитом, сделай что-нибудь самостоятельно!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

К текущему дню недели добавить класс

Автор Gover

Ответов: 5
Просмотров: 1203
Последний ответ 04.09.2016, 23:23:41
от effrit
Отображение результатов запроса в таблич

Автор 68pin

Ответов: 6
Просмотров: 1256
Последний ответ 17.12.2015, 09:41:50
от beliyadm
PageSpeed Insights находит на сайте непонятные страницы

Автор daddy

Ответов: 2
Просмотров: 2999
Последний ответ 14.12.2015, 18:44:47
от AlekVolsk
Не верно отображаеться редирект - ?

Автор warlocksp

Ответов: 0
Просмотров: 1078
Последний ответ 21.07.2015, 16:37:36
от warlocksp
Как прописать JavaScript позицию вывода ?

Автор warlocksp

Ответов: 3
Просмотров: 1411
Последний ответ 04.05.2015, 14:38:43
от warlocksp