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

Add Basic Interfaces and CI/CD for web interface #212

Closed
wants to merge 67 commits into from

Conversation

JackyZzZz
Copy link
Collaborator

@JackyZzZz JackyZzZz commented Jun 17, 2024

This PR introduces the basic interfaces of our package, including the intro and MaxMin page. Moreover, it established a complete CI/CD protocol to deploy the associated docker image to DockerHub and HuggingFace for deployment.

The docker image is deployed on DockerHub.

The application is live on HuggingFace.

There are a few things that should be checked before merging:

    • Create a DockerHub account for our organization for hosting the Docker image.
    • Create a HuggingFace account and space for our organzation to host the application.
    • Set up Github Secrets in the repo, including Dockerhub and HuggingFace credentials.

Here is a demo of this PR:

Demo.mp4

@FanwangM FanwangM changed the title Add Basic Interfaces and CI/CD Add Basic Interfaces and CI/CD for web interface Jun 17, 2024
Copy link

codecov bot commented Jun 17, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 95.89%. Comparing base (d931154) to head (d2d2937).
Report is 6 commits behind head on main.

Additional details and impacted files

Impacted file tree graph

@@            Coverage Diff             @@
##             main     #212      +/-   ##
==========================================
- Coverage   96.00%   95.89%   -0.11%     
==========================================
  Files           9        9              
  Lines         975      974       -1     
==========================================
- Hits          936      934       -2     
- Misses         39       40       +1     

see 1 file with indirect coverage changes

@FanwangM
Copy link
Collaborator

Hi @FanwangM, thank you for the comment!

That makes sense since this way the user can stay on our Github page to get the docker image without going to another site. I will also take a look at how to make this work too basides working on other interfaces. We can discuss this in our next meeting too since it looks like there are somewhat more setup for publishing images on Github.

I will update the workflow to push it to our official space. However, I noticed that the space you created is a streamlit space. Could you update this to a docker space maybe? I think streamlit space are for simpler apps so that the space will be looking for that app.py in the root of the folder to build the application. In our case it will be a package with our streamlit code in streamlit_app folder. So a docker space will use the Dockerfile we have in the root of our repo to start the interface application in a docker container where our package resides, which is also the space I've been using for testing.

Also, could you set the HF_TOKEN secret in the setting of our repo. This is required so that the workflow have appropriate permission to push to the HuggingFace. You can generate the token from HuggingFace and paste it in Github secrets.

Let me know if there is any questions~

The space has been converted to a docker space and the HF_TOKEN secret is set up as well. Please lt me know if there is a problem. @JackyZzZz

@JackyZzZz
Copy link
Collaborator Author

JackyZzZz commented Jun 27, 2024

Hi @FanwangM, I commented out the code in the workflow for building and pushing docker image. I also updated the command for pushing to HuggingFace. Could you run the workflow again to see if it works? I think it should work now.

@JackyZzZz
Copy link
Collaborator Author

JackyZzZz commented Jun 28, 2024

Hi @FanwangM ,I figured that we should use HEAD to represent the current branch where the pull request is on for pushing to the main branch on HuggingFace. This should fix the problem now hopefully. However, I am starting to think should we have like a middle layer for deployment testing? In the future, if other contributors make pull requests about the interface, I believe that we wouldn't want the changes to go live directly before it has been fully reviewed and tested. I can take a look into making it work as well once I finish all the interfaces.

@FanwangM
Copy link
Collaborator

Hi @FanwangM ,I figured that we should use HEAD to represent the current branch where the pull request is on for pushing to the main branch on HuggingFace. This should fix the problem now hopefully. However, I am starting to think should we have like a middle layer for deployment testing? In the future, if other contributors make pull requests about the interface, I believe that we wouldn't want the changes to go live directly before it has been fully reviewed and tested. I can take a look into making it work as well once I finish all the interfaces.

This is a good and important point! Thanks for bringing it up. We should have this on the to-do list.

@JackyZzZz
Copy link
Collaborator Author

Hi @FanwangM, I noticed the pushing to HuggingFace is still failing for some reason. Just curious, did you setup the HF_TOKEN as the password of the account or the user access token generated by HuggingFace. From the error message, it looks like it's setting up using the password right now, which is not supported anymore.

image

You can refer to this tutorial for how to generate the access token up if you haven't already. We also need to give all the necessary permissions to the token such as write access etc to allow our github action to be able to push.

@FanwangM
Copy link
Collaborator

Hi @FanwangM, I noticed the pushing to HuggingFace is still failing for some reason. Just curious, did you setup the HF_TOKEN as the password of the account or the user access token generated by HuggingFace. From the error message, it looks like it's setting up using the password right now, which is not supported anymore.

image

You can refer to this tutorial for how to generate the access token up if you haven't already. We also need to give all the necessary permissions to the token such as write access etc to allow our github action to be able to push.

Thanks for checking this. But I did set up the HF_token as the repo secret.

Did you successfully deployed the application from your end using your own HF account before?

@JackyZzZz
Copy link
Collaborator Author

JackyZzZz commented Jun 29, 2024

Yes. I just deployed another version on my own space minutes ago. Did you set it up as HF_TOKEN or HF_token? I think it's also case-sensitive, so these two are not the same thing.

@FanwangM
Copy link
Collaborator

We have HF_TOKEN.

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.

2 participants