Files
blog.pyaqa.ru/static/css/markdown.css
Sergey Vanyushkin 46cc06b596 feat: RBAC E2E тесты и фикс admin-прав для редактирования постов
Основные изменения:
- Добавлены E2E тесты для проверки ownership (TC-E2E-102/103):
  * test_admin_can_edit_any_post — admin может редактировать любой пост
  * test_user_cannot_edit_other_users_post — user не может редактировать чужой пост
- Исправлены use cases (UpdatePost, DeletePost, PublishPost) — добавлена проверка роли admin
- Обновлены web routes и API routes для передачи роли в use cases
- Добавлены unit тесты для admin-сценариев

Реструктуризация тестов:
- Удалены старые API тесты (tests/api/) — требуют переработки
- Удалены старые integration тесты (tests/integration/)
- Переработаны E2E тесты: удалены старые, добавлены новые с POM
- Добавлена документация тестов: FEATURE_*.md, TEST_MODEL.md, AGENTS.md

Инфраструктура:
- Добавлен MockKeycloakClient для dev-режима
- Добавлены статические файлы: EasyMDE, Highlight.js, стили markdown
- Обновлены шаблоны: base.html, post_form.html, post_detail.html
- Обновлена DI конфигурация и провайдеры

Документация:
- tests/FEATURE_RBAC.md — матрица тестов RBAC
- tests/FEATURE_POST_LIFECYCLE.md — тесты жизненного цикла поста
- tests/FEATURE_DOMAIN_FOUNDATION.md — тесты доменного слоя
- tests/FEATURE_INFRASTRUCTURE.md — тесты инфраструктуры
- tests/TEST_MODEL.md — глобальная матрица покрытия
- app/presentation/web/AGENTS.md — гайд по Web UI
- tests/AGENTS.md — гайд по тестированию
2026-05-07 19:55:15 +03:00

132 lines
2.5 KiB
CSS

.markdown-body h1,
.markdown-body h2,
.markdown-body h3,
.markdown-body h4,
.markdown-body h5,
.markdown-body h6 {
margin-top: 1.5em;
margin-bottom: 0.5em;
font-weight: 600;
line-height: 1.25;
}
.markdown-body h1 { font-size: 2em; border-bottom: 1px solid var(--color-border); padding-bottom: 0.3em; }
.markdown-body h2 { font-size: 1.5em; border-bottom: 1px solid var(--color-border); padding-bottom: 0.3em; }
.markdown-body h3 { font-size: 1.25em; }
.markdown-body h4 { font-size: 1em; }
.markdown-body h5 { font-size: 0.875em; }
.markdown-body h6 { font-size: 0.85em; color: var(--color-text-light); }
.markdown-body p {
margin-bottom: 1em;
line-height: 1.6;
}
.markdown-body ul,
.markdown-body ol {
margin-bottom: 1em;
padding-left: 2em;
}
.markdown-body li {
margin-bottom: 0.25em;
}
.markdown-body blockquote {
margin: 0 0 1em;
padding: 0 1em;
color: var(--color-text-light);
border-left: 0.25em solid var(--color-border);
}
.markdown-body pre {
margin-bottom: 1em;
padding: 1em;
overflow: auto;
font-size: 0.875em;
line-height: 1.45;
background-color: var(--color-box-body);
border-radius: 6px;
}
.markdown-body pre code {
padding: 0;
background-color: transparent;
font-size: inherit;
}
.markdown-body .highlight {
margin-bottom: 1em;
padding: 1em;
overflow: auto;
font-size: 0.875em;
line-height: 1.45;
background-color: var(--color-box-body);
border-radius: 6px;
}
.markdown-body .highlight pre {
margin: 0;
padding: 0;
overflow: visible;
background-color: transparent;
}
.markdown-body table {
margin-bottom: 1em;
border-collapse: collapse;
border-spacing: 0;
width: 100%;
overflow: auto;
}
.markdown-body table th,
.markdown-body table td {
padding: 0.5em 1em;
border: 1px solid var(--color-border);
}
.markdown-body table th {
font-weight: 600;
background-color: var(--color-box-body);
}
.markdown-body table tr:nth-child(2n) {
background-color: var(--color-box-body);
}
.markdown-body hr {
height: 0.25em;
padding: 0;
margin: 1.5em 0;
background-color: var(--color-border);
border: 0;
}
.markdown-body a {
color: var(--color-primary);
text-decoration: none;
}
.markdown-body a:hover {
text-decoration: underline;
}
.markdown-body img {
max-width: 100%;
height: auto;
border-radius: 6px;
}
.markdown-body strong {
font-weight: 600;
}
.markdown-body em {
font-style: italic;
}
.markdown-body del {
text-decoration: line-through;
}