Brak opisu

Alexander Musikhin 71e542f33b Added nullable to brand field, removed timestamps 1 rok temu
app 71e542f33b Added nullable to brand field, removed timestamps 1 rok temu
bootstrap 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
config 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
database 71e542f33b Added nullable to brand field, removed timestamps 1 rok temu
public 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
resources 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
routes 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
storage 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
tests 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
.editorconfig 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
.env.example 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
.gitattributes 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
.gitignore 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
README.md 917c450863 Readme modified 1 rok temu
artisan 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
composer.json 09aa268898 added ext-pdo extension to composer json 1 rok temu
composer.lock 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
package-lock.json 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
package.json 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
phpunit.xml 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu
vite.config.js 36bfee6e13 Initial commit: installed laravel, created migrations and models 1 rok temu

README.md

Test task

Тестовая задача hh.ru для Social Media Holding

Необходимо получить данные с сайта https://dummyjson.com/docs/products и занести их в базу данных отобрав по iPhone.

Для решения задачи был выбран фреймворк Laravel и БД SQLite. Были написаны миграции и модели в соответствии с документацией, с небольшими отклонениями:

  • в именах полей БД использовался snake_case
  • некоторые вложенные поля продукта были вынесены на уровень выше

Была создана основная таблица products и связанные с ней по принципу один-ко-многим product_images и product_reviews, а также связанная по принципу многие-ко-многим таблица tags.

Непосредственно получение данных и запись в БД реализовано через консольные команды Laravel.

Был создан абстрактный класс для получения данных от DummyJSON и на его основе класс, который получив нужные данные преобразует их и записывает в БД. Валидация данных в данном случае не реализована, т.к. проект тестовый.

Команда работает по принципу обновить или создать, то есть исключено дублирование данных. Данные в связанных таблицах пересоздаются при каждом обновлении, т.к. нет поля, позволяющего однозначно идентифицировать запись.