Skip to content

Commit

Permalink
feat: Initialize App
Browse files Browse the repository at this point in the history
  • Loading branch information
Diya050 committed Jul 12, 2023
0 parents commit d77f545
Show file tree
Hide file tree
Showing 16 changed files with 359 additions and 0 deletions.
102 changes: 102 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@

name: CI

on:
push:
branches:
- develop
pull_request:

concurrency:
group: develop-todo-${{ github.event.number }}
cancel-in-progress: true

jobs:
tests:
runs-on: ubuntu-latest
strategy:
fail-fast: false
name: Server

services:
redis-cache:
image: redis:alpine
ports:
- 13000:6379
redis-queue:
image: redis:alpine
ports:
- 11000:6379
redis-socketio:
image: redis:alpine
ports:
- 12000:6379
mariadb:
image: mariadb:10.6
env:
MYSQL_ROOT_PASSWORD: root
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping" --health-interval=5s --health-timeout=2s --health-retries=3

steps:
- name: Clone
uses: actions/checkout@v3

- name: Setup Python
uses: actions/setup-python@v4
with:
python-version: '3.10'

- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 16
check-latest: true

- name: Cache pip
uses: actions/cache@v2
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/*requirements.txt', '**/pyproject.toml', '**/setup.py', '**/setup.cfg') }}
restore-keys: |
${{ runner.os }}-pip-
${{ runner.os }}-
- name: Get yarn cache directory path
id: yarn-cache-dir-path
run: 'echo "dir=$(yarn cache dir)" >> $GITHUB_OUTPUT'

- uses: actions/cache@v3
id: yarn-cache
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
- name: Setup
run: |
pip install frappe-bench
bench init --skip-redis-config-generation --skip-assets --python "$(which python)" ~/frappe-bench
mysql --host 127.0.0.1 --port 3306 -u root -proot -e "SET GLOBAL character_set_server = 'utf8mb4'"
mysql --host 127.0.0.1 --port 3306 -u root -proot -e "SET GLOBAL collation_server = 'utf8mb4_unicode_ci'"
- name: Install
working-directory: /home/runner/frappe-bench
run: |
bench get-app todo $GITHUB_WORKSPACE
bench setup requirements --dev
bench new-site --db-root-password root --admin-password admin test_site
bench --site test_site install-app todo
bench build
env:
CI: 'Yes'

- name: Run Tests
working-directory: /home/runner/frappe-bench
run: |
bench --site test_site set-config allow_tests true
bench --site test_site run-tests --app todo
env:
TYPE: server
6 changes: 6 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
.DS_Store
*.pyc
*.egg-info
*.swp
tags
node_modules
18 changes: 18 additions & 0 deletions MANIFEST.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
include MANIFEST.in
include requirements.txt
include *.json
include *.md
include *.py
include *.txt
recursive-include todo *.css
recursive-include todo *.csv
recursive-include todo *.html
recursive-include todo *.ico
recursive-include todo *.js
recursive-include todo *.json
recursive-include todo *.md
recursive-include todo *.png
recursive-include todo *.py
recursive-include todo *.svg
recursive-include todo *.txt
recursive-exclude todo *.pyc
7 changes: 7 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
## ToDo

This is a to-do list app.

#### License

y
1 change: 1 addition & 0 deletions license.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
License: y
1 change: 1 addition & 0 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# frappe -- https://github.com/frappe/frappe is installed via 'bench init'
19 changes: 19 additions & 0 deletions setup.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
from setuptools import setup, find_packages

with open("requirements.txt") as f:
install_requires = f.read().strip().split("\n")

# get version from __version__ variable in todo/__init__.py
from todo import __version__ as version

setup(
name="todo",
version=version,
description="This is a to-do list app.",
author="Diya",
author_email="[email protected]",
packages=find_packages(),
zip_safe=False,
include_package_data=True,
install_requires=install_requires
)
3 changes: 3 additions & 0 deletions todo/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@

__version__ = '0.0.1'

Empty file added todo/config/__init__.py
Empty file.
201 changes: 201 additions & 0 deletions todo/hooks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,201 @@
from . import __version__ as app_version

app_name = "todo"
app_title = "ToDo"
app_publisher = "Diya"
app_description = "This is a to-do list app."
app_email = "[email protected]"
app_license = "y"

# Includes in <head>
# ------------------

# include js, css files in header of desk.html
# app_include_css = "/assets/todo/css/todo.css"
# app_include_js = "/assets/todo/js/todo.js"

# include js, css files in header of web template
# web_include_css = "/assets/todo/css/todo.css"
# web_include_js = "/assets/todo/js/todo.js"

# include custom scss in every website theme (without file extension ".scss")
# website_theme_scss = "todo/public/scss/website"

# include js, css files in header of web form
# webform_include_js = {"doctype": "public/js/doctype.js"}
# webform_include_css = {"doctype": "public/css/doctype.css"}

# include js in page
# page_js = {"page" : "public/js/file.js"}

# include js in doctype views
# doctype_js = {"doctype" : "public/js/doctype.js"}
# doctype_list_js = {"doctype" : "public/js/doctype_list.js"}
# doctype_tree_js = {"doctype" : "public/js/doctype_tree.js"}
# doctype_calendar_js = {"doctype" : "public/js/doctype_calendar.js"}

# Home Pages
# ----------

# application home page (will override Website Settings)
# home_page = "login"

# website user home page (by Role)
# role_home_page = {
# "Role": "home_page"
# }

# Generators
# ----------

# automatically create page for each record of this doctype
# website_generators = ["Web Page"]

# Jinja
# ----------

# add methods and filters to jinja environment
# jinja = {
# "methods": "todo.utils.jinja_methods",
# "filters": "todo.utils.jinja_filters"
# }

# Installation
# ------------

# before_install = "todo.install.before_install"
# after_install = "todo.install.after_install"

# Uninstallation
# ------------

# before_uninstall = "todo.uninstall.before_uninstall"
# after_uninstall = "todo.uninstall.after_uninstall"

# Desk Notifications
# ------------------
# See frappe.core.notifications.get_notification_config

# notification_config = "todo.notifications.get_notification_config"

# Permissions
# -----------
# Permissions evaluated in scripted ways

# permission_query_conditions = {
# "Event": "frappe.desk.doctype.event.event.get_permission_query_conditions",
# }
#
# has_permission = {
# "Event": "frappe.desk.doctype.event.event.has_permission",
# }

# DocType Class
# ---------------
# Override standard doctype classes

# override_doctype_class = {
# "ToDo": "custom_app.overrides.CustomToDo"
# }

# Document Events
# ---------------
# Hook on document methods and events

# doc_events = {
# "*": {
# "on_update": "method",
# "on_cancel": "method",
# "on_trash": "method"
# }
# }

# Scheduled Tasks
# ---------------

# scheduler_events = {
# "all": [
# "todo.tasks.all"
# ],
# "daily": [
# "todo.tasks.daily"
# ],
# "hourly": [
# "todo.tasks.hourly"
# ],
# "weekly": [
# "todo.tasks.weekly"
# ],
# "monthly": [
# "todo.tasks.monthly"
# ],
# }

# Testing
# -------

# before_tests = "todo.install.before_tests"

# Overriding Methods
# ------------------------------
#
# override_whitelisted_methods = {
# "frappe.desk.doctype.event.event.get_events": "todo.event.get_events"
# }
#
# each overriding function accepts a `data` argument;
# generated from the base implementation of the doctype dashboard,
# along with any modifications made in other Frappe apps
# override_doctype_dashboards = {
# "Task": "todo.task.get_dashboard_data"
# }

# exempt linked doctypes from being automatically cancelled
#
# auto_cancel_exempted_doctypes = ["Auto Repeat"]

# Ignore links to specified DocTypes when deleting documents
# -----------------------------------------------------------

# ignore_links_on_delete = ["Communication", "ToDo"]

# Request Events
# ----------------
# before_request = ["todo.utils.before_request"]
# after_request = ["todo.utils.after_request"]

# Job Events
# ----------
# before_job = ["todo.utils.before_job"]
# after_job = ["todo.utils.after_job"]

# User Data Protection
# --------------------

# user_data_fields = [
# {
# "doctype": "{doctype_1}",
# "filter_by": "{filter_by}",
# "redact_fields": ["{field_1}", "{field_2}"],
# "partial": 1,
# },
# {
# "doctype": "{doctype_2}",
# "filter_by": "{filter_by}",
# "partial": 1,
# },
# {
# "doctype": "{doctype_3}",
# "strict": False,
# },
# {
# "doctype": "{doctype_4}"
# }
# ]

# Authentication and authorization
# --------------------------------

# auth_hooks = [
# "todo.auth.validate"
# ]
1 change: 1 addition & 0 deletions todo/modules.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
ToDo
Empty file added todo/patches.txt
Empty file.
Empty file added todo/public/.gitkeep
Empty file.
Empty file added todo/templates/__init__.py
Empty file.
Empty file.
Empty file added todo/todo/__init__.py
Empty file.

0 comments on commit d77f545

Please sign in to comment.