Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add ability in robyn cli to scaffold example programs with various DBs #584

Merged
merged 16 commits into from
Oct 30, 2023

Conversation

bwdq
Copy link
Contributor

@bwdq bwdq commented Aug 15, 2023

Fixes #511 and adds some example code for scaffolding Sqlite, Postgres, Mongo, Prisma, and SQLAlchemy.

@netlify
Copy link

netlify bot commented Aug 15, 2023

👷 Deploy request for robyn pending review.

Visit the deploys page to approve it

Name Link
🔨 Latest commit 386a040

@codspeed-hq
Copy link

codspeed-hq bot commented Aug 15, 2023

CodSpeed Performance Report

Merging #584 will not alter performance

Comparing bwdq:scaffold-v3 (8b0cb47) with main (f4a9de0)

Summary

✅ 106 untouched benchmarks

@sansyrox
Copy link
Member

Hey @bwdq 👋

Great work 😄

I will have a thorough look over the weekend but this great work so far!

Copy link
Member

@sansyrox sansyrox left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @bwdq 👋

Great work 😄 I have a few suggestions. Do let me know if you have any questions from me 😄

Also, can you please bring the Dockerfile in the scaffold folder instead of generating it on the fly?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

All these databases would also require certain dependencies. Can we update the docker files accordingly?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have updated the Docker files for the databases. When I ran docker it errored 'uvloop not found' so uvloop should be a mandatory dependency instead of optional.

Comment on lines 35 to 37
project_dir = result[0]
docker = result[1]
project_type = result[2]
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
project_dir = result[0]
docker = result[1]
project_type = result[2]
project_dir, docker, project_type = result

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I tried this and it did not parse correctly so I left it as is

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bwdq , what do you mean by this? What error were you getting?

We can return a dictionary instead of a tuple if there is an issue

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would advise returning result as dict instead of tuple, will make it more clear what is what and avoid future issues in case a new question is added or the order changes.

robyn/__main__.py Outdated Show resolved Hide resolved

# install prisma cli
# initialize prisma with "prisma generate"
# then "prisma migrate dev" and name migration dev
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bwdq 👋

Can you please explain the line here?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These are instructions to the user because prisma won't "just work" and requires some setup. I'm not sure what the optimal solution here is. I don't want to execute bash commands silently.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

hey @bwdq 👋

We can add a small readme inside every folder. Doesn't need to be too fancy. Can just contain these commands.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have moved the python comments to README's.

res = cur.execute("SELECT name FROM sqlite_master")
th = res.fetchone()
print(th)
return "Hello World!"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I believe that we should be including res in the final response.

Copy link
Contributor Author

@bwdq bwdq Sep 25, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done
table_name = th[0] return f"Hello World! {table_name}"

Comment on lines 47 to 70
if project_type == "sqlite":
f.write(open("robyn/scaffold/sqlite/app.py", "r").read())
elif project_type == "postgres":
f.write(open("robyn/scaffold/postgres/app.py", "r").read())
# copy README.md
readme_path = os.path.join(project_dir, "README.md")
with open(readme_path, "w") as f_r:
f_r.write(open("robyn/scaffold/postgres/README.md", "r").read())
elif project_type == "mongo":
f.write(open("robyn/scaffold/mongo/app.py", "r").read())
elif project_type == "sqlalchemy":
f.write(open("robyn/scaffold/sqlalchemy/app.py", "r").read())
elif project_type == "prisma":
f.write(open("robyn/scaffold/prisma/app.py", "r").read())
# copy schema.prisma
schema_path = os.path.join(project_dir, "schema.prisma")
with open(schema_path, "w") as f_s:
f_s.write(open("robyn/scaffold/prisma/schema.prisma", "r").read())
# copy README.md
readme_path = os.path.join(project_dir, "README.md")
with open(readme_path, "w") as f_r:
f_r.write(open("robyn/scaffold/prisma/README.md", "r").read())
else:
f.write(open("robyn/scaffold/no-db/app.py", "r").read())
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I wonder if there is a cleaner way to implement this?

can you store the file_name and file_paths in a dictionary and then try accessing it?

@IdoKendo do you have any thoughts on this?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would simplify this whole block to something like these 3 lines:

base_path = f"robyn/scaffold/{project_type}"
shutil.copyfile(f"{base_path}/README.md", readme_path)
shutil.copyfile(f"{base_path}/app.py",  app_file_path)

Just make sure the project_type default is no-db 😃
Can add some guard clauses to be extra safe, but I think InquirerPy does that for you out-of-the-box.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Upon further review of the code, can even do it as simple as:

from distutils.dir_util import copy_tree

copy_tree(project_dir, f"robyn/scaffold/{project_type}")

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is much simpler but at the time I didn't want to add a new dependency. I've switched to this now.

Comment on lines 77 to 87
if project_type == "sqlite":
f.write(open("robyn/scaffold/sqlite/Dockerfile", "r").read())
elif project_type == "postgres":
f.write(open("robyn/scaffold/postgres/Dockerfile", "r").read())
elif project_type == "mongo":
f.write(open("robyn/scaffold/mongo/Dockerfile", "r").read())
elif project_type == "sqlalchemy":
f.write(open("robyn/scaffold/sqlalchemy/Dockerfile", "r").read())
elif project_type == "prisma":
f.write(open("robyn/scaffold/prisma/Dockerfile", "r").read())
else:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same for this

Copy link
Contributor

@IdoKendo IdoKendo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @bwdq 👋 Nice job!
I've added some comments to simplify and improve upon the changes. LMK if there's anything I can help with!

Comment on lines 35 to 37
project_dir = result[0]
docker = result[1]
project_type = result[2]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would advise returning result as dict instead of tuple, will make it more clear what is what and avoid future issues in case a new question is added or the order changes.

robyn/__main__.py Outdated Show resolved Hide resolved
robyn/scaffold/mongo/Dockerfile Outdated Show resolved Hide resolved
Comment on lines 47 to 70
if project_type == "sqlite":
f.write(open("robyn/scaffold/sqlite/app.py", "r").read())
elif project_type == "postgres":
f.write(open("robyn/scaffold/postgres/app.py", "r").read())
# copy README.md
readme_path = os.path.join(project_dir, "README.md")
with open(readme_path, "w") as f_r:
f_r.write(open("robyn/scaffold/postgres/README.md", "r").read())
elif project_type == "mongo":
f.write(open("robyn/scaffold/mongo/app.py", "r").read())
elif project_type == "sqlalchemy":
f.write(open("robyn/scaffold/sqlalchemy/app.py", "r").read())
elif project_type == "prisma":
f.write(open("robyn/scaffold/prisma/app.py", "r").read())
# copy schema.prisma
schema_path = os.path.join(project_dir, "schema.prisma")
with open(schema_path, "w") as f_s:
f_s.write(open("robyn/scaffold/prisma/schema.prisma", "r").read())
# copy README.md
readme_path = os.path.join(project_dir, "README.md")
with open(readme_path, "w") as f_r:
f_r.write(open("robyn/scaffold/prisma/README.md", "r").read())
else:
f.write(open("robyn/scaffold/no-db/app.py", "r").read())
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Upon further review of the code, can even do it as simple as:

from distutils.dir_util import copy_tree

copy_tree(project_dir, f"robyn/scaffold/{project_type}")

@sansyrox
Copy link
Member

Thanks for the review @IdoKendo 😄

I wasn't aware about this feature

from distutils.dir_util import copy_tree

@sansyrox
Copy link
Member

Any updates on this @bwdq ?

@vercel
Copy link

vercel bot commented Sep 25, 2023

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
robyn ✅ Ready (Inspect) Visit Preview 💬 Add feedback Oct 30, 2023 9:55pm

@bwdq
Copy link
Contributor Author

bwdq commented Sep 25, 2023

I have updated and simplified the logic in main. I'm still having issues with the robyn resetting the connection when running on docker and some testing would be helpful.

@sansyrox
Copy link
Member

Hey @bwdq 👋

I'm still having issues with the robyn resetting the connection when running on docker and some testing would be helpful.

Can you please explain what you mean here? I don't understand what you mean by "resetting" the connection.

@bwdq
Copy link
Contributor Author

bwdq commented Oct 1, 2023

The issue isn't really related to this PR because it's reproducible on the main branch so I've opened a separate issue for it.
#621

@sansyrox
Copy link
Member

sansyrox commented Oct 3, 2023

Hey @bwdq 👋

Is the PR up for review?

@bwdq
Copy link
Contributor Author

bwdq commented Oct 3, 2023

Hey @bwdq 👋

Is the PR up for review?

Yes it is. The docker issue is now fixed.

@sansyrox
Copy link
Member

sansyrox commented Oct 8, 2023

Hey @bwdq 👋

I have two suggestions for this PR

  • there are some conflicts. Can we please resolve them?
  • can we add some documentation regarding the new change in the new_docs folder?

robyn/scaffold/no-db/Dockerfile Show resolved Hide resolved
robyn/scaffold/postgres/app.py Show resolved Hide resolved
Copy link
Member

@sansyrox sansyrox left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @bwdq 👋

I was going trying your branch and when I run the command python -m robyn --create

I get the following error

Please select project type (Mongo/Postgres/Sqlalchemy/Prisma):  Sqlite
Creating a new Robyn project '.'...
Traceback (most recent call last):
  File "/Users/sanskar/.pyenv/versions/3.10.7/lib/python3.10/runpy.py", line 196, in _run_module_as_main
    return _run_code(code, main_globals, None,
  File "/Users/sanskar/.pyenv/versions/3.10.7/lib/python3.10/runpy.py", line 86, in _run_code
    exec(code, run_globals)
  File "/Users/sanskar/repos/robyn/robyn/__main__.py", line 68, in <module>
    create_robyn_app()
  File "/Users/sanskar/repos/robyn/robyn/__main__.py", line 51, in create_robyn_app
    copy_tree(f"robyn/scaffold/{project_type}/", project_dir)
  File "/Users/sanskar/repos/robyn/venv/lib/python3.10/site-packages/setuptools/_distutils/dir_util.py", line 135, in copy_tree
    raise DistutilsFileError("cannot copy tree '%s': not a directory" % src)
distutils.errors.DistutilsFileError: cannot copy tree 'robyn/scaffold/sqlite/': not a directory

And this is happening for every selection. Can you please have a look?

@Mr-Sunglasses
Copy link
Contributor

@Mr-Sunglasses , can you please explain a bit more? What would be different?

@sansyrox I'm taking about sqlalchemy + alembic migration template but we can do after we migrate create_robyn_app to another repo ( #659 )

robyn/__main__.py Outdated Show resolved Hide resolved
@sansyrox sansyrox changed the title [feat] issue #511 add ability in robyn cli to scaffold example programs with various DB's #511 add ability in robyn cli to scaffold example programs with various DB's Oct 30, 2023
@sansyrox sansyrox changed the title #511 add ability in robyn cli to scaffold example programs with various DB's feat: add ability in robyn cli to scaffold example programs with various DB's Oct 30, 2023
@sansyrox
Copy link
Member

@Mr-Sunglasses , can you please explain a bit more? What would be different?

@sansyrox I'm taking about sqlalchemy + alembic migration template but we can do after we migrate create_robyn_app to another repo ( #659 )

@Mr-Sunglasses , can you please make an issue for the same?

@Mr-Sunglasses
Copy link
Contributor

@Mr-Sunglasses , can you please explain a bit more? What would be different?

@sansyrox I'm taking about sqlalchemy + alembic migration template but we can do after we migrate create_robyn_app to another repo ( #659 )

@Mr-Sunglasses , can you please make an issue for the same?

Sure.

Copy link
Contributor

@Mr-Sunglasses Mr-Sunglasses left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM Great work Team 🙌🏻

Copy link
Contributor

@IdoKendo IdoKendo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM 🔥

@sansyrox
Copy link
Member

Thank you @IdoKendo and @Mr-Sunglasses 😄 ✨

@sansyrox sansyrox changed the title feat: add ability in robyn cli to scaffold example programs with various DB's feat: add ability in robyn cli to scaffold example programs with various DBs Oct 30, 2023
@sansyrox sansyrox merged commit 9f0c23d into sparckles:main Oct 30, 2023
44 of 58 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Robyn CLI - Add ability to scaffold different kinds of projects
4 participants