generated from Sithas/conan_template
Compare commits
2 Commits
0ee1beacfa
...
9bd4187e9b
| Author | SHA1 | Date | |
|---|---|---|---|
| 9bd4187e9b | |||
| bff937f9a7 |
+29
-26
@@ -1,4 +1,4 @@
|
||||
cmake_minimum_required(VERSION 3.29.8)
|
||||
cmake_minimum_required(VERSION 3.28.3)
|
||||
project(UpAndDown)
|
||||
|
||||
set(CMAKE_CXX_STANDARD 23)
|
||||
@@ -10,10 +10,13 @@ endif ()
|
||||
|
||||
set(Boost_USE_STATIC_LIBS ON)
|
||||
set(Boost_USE_MULTITHREADED ON)
|
||||
set(Boost_INCLUDE_DIR ${BOOST_ROOT})
|
||||
set(Boost_LIBRARY_DIR "${BOOST_ROOT}/stage/lib")
|
||||
|
||||
find_package(Boost 1.88.0 REQUIRED COMPONENTS filesystem json log system filesystem url)
|
||||
if (WIN32)
|
||||
set(Boost_INCLUDE_DIR ${BOOST_ROOT})
|
||||
set(Boost_LIBRARY_DIR "${BOOST_ROOT}/stage/lib")
|
||||
endif ()
|
||||
|
||||
find_package(Boost 1.83.0 REQUIRED COMPONENTS filesystem json log system filesystem url)
|
||||
if (Boost_FOUND)
|
||||
include_directories(${Boost_INCLUDE_DIR})
|
||||
endif ()
|
||||
@@ -38,8 +41,8 @@ add_executable(App ./src/main.cpp
|
||||
./src/db/mysql_connector.cpp
|
||||
./src/db/mysql_connector.h
|
||||
./src/DAO/IUserDAO.h
|
||||
src/dtos/user_dto.h
|
||||
src/dtos/medication_dto.h
|
||||
./src/dtos/user_dto.h
|
||||
./src/dtos/medication_dto.h
|
||||
./src/DAO/MySQLUserDAO.cpp
|
||||
./src/DAO/MySQLUserDAO.h
|
||||
./src/endpoints_handlers/IExecutor.h
|
||||
@@ -52,26 +55,26 @@ add_executable(App ./src/main.cpp
|
||||
./src/endpoints_handlers/AuthLoginExecutor.h
|
||||
./src/exceptions/session_exception.cpp
|
||||
./src/exceptions/session_exception.h
|
||||
src/log/Log.h
|
||||
src/log/Log.cpp
|
||||
tests/fixtures/AuthFixture.h
|
||||
src/endpoints_handlers/GetUserMedicationsExecutor.h
|
||||
src/DAO/IMedicationsDAO.h
|
||||
src/DAO/MySQLMedicationsDAO.h
|
||||
src/DAO/MySQLMedicationsDAO.cpp
|
||||
src/dtos/user_treatment_scheme_dto.h
|
||||
src/DAO/IUserTreatmentSchemesDAO.h
|
||||
src/DAO/MySQLUserTreatmentSchemesDAO.cpp
|
||||
src/DAO/MySQLUserTreatmentSchemesDAO.h
|
||||
src/endpoints_handlers/GetUserTreatmentSchemeExecutor.h
|
||||
src/endpoints_handlers/GetDiariesExecutor.h
|
||||
src/endpoints_handlers/PostDiaryExecutor.h
|
||||
src/endpoints_handlers/PutDiaryExecutor.h
|
||||
src/endpoints_handlers/DeleteDiaryExecutor.h
|
||||
src/DAO/IDiariesDAO.h
|
||||
src/dtos/diary_dto.h
|
||||
src/DAO/MySQLDiariesDao.cpp
|
||||
src/DAO/MySQLDiariesDao.h
|
||||
./src/log/Log.h
|
||||
./src/log/Log.cpp
|
||||
./tests/fixtures/AuthFixture.h
|
||||
./src/endpoints_handlers/GetUserMedicationsExecutor.h
|
||||
./src/DAO/IMedicationsDAO.h
|
||||
./src/DAO/MySQLMedicationsDAO.h
|
||||
./src/DAO/MySQLMedicationsDAO.cpp
|
||||
./src/dtos/user_treatment_scheme_dto.h
|
||||
./src/DAO/IUserTreatmentSchemesDAO.h
|
||||
./src/DAO/MySQLUserTreatmentSchemesDAO.cpp
|
||||
./src/DAO/MySQLUserTreatmentSchemesDAO.h
|
||||
./src/endpoints_handlers/GetUserTreatmentSchemeExecutor.h
|
||||
./src/endpoints_handlers/GetDiariesExecutor.h
|
||||
./src/endpoints_handlers/PostDiaryExecutor.h
|
||||
./src/endpoints_handlers/PutDiaryExecutor.h
|
||||
./src/endpoints_handlers/DeleteDiaryExecutor.h
|
||||
./src/DAO/IDiariesDAO.h
|
||||
./src/dtos/diary_dto.h
|
||||
./src/DAO/MySQLDiariesDao.cpp
|
||||
./src/DAO/MySQLDiariesDao.h
|
||||
)
|
||||
|
||||
target_link_libraries(App PRIVATE Boost::boost
|
||||
|
||||
+38
@@ -0,0 +1,38 @@
|
||||
FROM ubuntu:24.04
|
||||
|
||||
ARG CONCPP_VER=9.4.0
|
||||
ARG CONCPP_TGZ=mysql-connector-c++-${CONCPP_VER}-linux-glibc2.28-x86-64bit.tar.gz
|
||||
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
ca-certificates curl xz-utils \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# MySQL xDevAPI install
|
||||
RUN curl -fsSL -o concpp.tgz \
|
||||
"https://dev.mysql.com/get/Downloads/Connector-C++/${CONCPP_TGZ}" \
|
||||
&& mkdir -p /opt \
|
||||
&& tar -xzf concpp.tgz -C /opt \
|
||||
&& rm concpp.tgz \
|
||||
&& found_dir="$(ls -1 /opt | grep -E '^mysql-connector-c\+\+-'"${CONCPP_VER}"'-')" \
|
||||
&& mv "/opt/${found_dir}" /opt/mysql-concpp
|
||||
|
||||
# CMake install
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
cmake build-essential \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# Boost install
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
libboost-all-dev \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# Project copy
|
||||
WORKDIR /project
|
||||
COPY . /project
|
||||
RUN set -eux; pwd; ls -la /project; test -f /project/CMakeLists.txt
|
||||
|
||||
# Build & Run project
|
||||
RUN mkdir /project/dist
|
||||
RUN ls -la /project
|
||||
RUN cmake /project/dist/.. -Dmysql-concpp_DIR=/opt/mysql-concpp
|
||||
RUN cmake --build /project/dist
|
||||
@@ -1,3 +1,7 @@
|
||||
# Запуск:
|
||||
- cmake .. -DBOOST_ROOT=C:\Libs\boost_1_88_0 -Dmysql-concpp_DIR=C:\Libs\mysql_connector
|
||||
- cmake --build .
|
||||
|
||||
# TODO:
|
||||
|
||||
- ~~Сделать реальные исполнители(executors) для регистрации, авторизации, логаута~~
|
||||
@@ -21,17 +25,22 @@
|
||||
- Посмотреть пулл соединений(Object pool) при использовании базы данных(посмотреть api MySQL-Connector)
|
||||
- Посмотреть и подумать, что лучше - корутины или многопоточность?
|
||||
- UseCase'ы по работе с личным кабинетом
|
||||
- Научиться поднимать базы данных под каждый тест - научиться Docker - docker-compose - а если тест что-то должен заполнить, то он заполняет в самом начале()
|
||||
- Возможно, сделать тесты на CI/CD - приоритет - низкий
|
||||
- Найти слабые места в C++ -- std::forward, universal reference, просмотреть про decltype(почитать статьи)
|
||||
- Написать фронтенд для MVP
|
||||
- Разобрать decltype и auto по статье
|
||||
- ~~Разобрать decltype и auto по статье~~
|
||||
- Подготовить резюме для тестовых собесов
|
||||
- DockerHosting.ru - купить аренду после того, как будет готов фронт и бэк
|
||||
До 27.01.2026
|
||||
- ~~Подобрать сервер по параметрам. Использовать linux.~~ DockerHosting.ru
|
||||
- ~~Подобрать сервер по параметрам. Использовать linux.~~
|
||||
- ~~Перевести string на string_view~~
|
||||
- ~~Попробовать nodiscard к executoru~~
|
||||
- ~~Добить 2 ручки~~
|
||||
- Сделать тесты для ручек
|
||||
До 10.02.2026
|
||||
- Сделать 2-3 теста
|
||||
- Продвинуться по фронтенду(форма авторизации и логина)
|
||||
- Сделать Dockerfile & Docker-compose(очищать и заполнять базу после каждого тест-кейса)
|
||||
- Возможно, сделать тесты на CI/CD - приоритет - низкий
|
||||
- Научиться поднимать базы данных под каждый тест - научиться Docker - docker-compose - а если тест что-то должен заполнить, то он заполняет в самом начале
|
||||
- Проставить const на немутабельные объекты
|
||||
|
||||
# План
|
||||
1)Добить бэкенд(2 ручки) (до февраля)
|
||||
|
||||
@@ -143,7 +143,7 @@ void MySqlDiariesDAO::UpdateDiary(
|
||||
diary_uuid.data()
|
||||
);
|
||||
|
||||
auto res = stmt.execute();
|
||||
const auto res = stmt.execute();
|
||||
|
||||
if (res.getAffectedItemsCount() == 0) {
|
||||
throw session_exception(boost::beast::http::status::not_found, "Diary not found");
|
||||
|
||||
Reference in New Issue
Block a user