-
Notifications
You must be signed in to change notification settings - Fork 11
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
Insert URL to specific pages #4
Comments
It will be super-useful to have a list of Also to handle the special case: No changes in docs. Most PRs (unfortunately) don't contain documentation changes. This will be interesting to explore in the future. If, however, there is automated API docs, we might have a situation where almost all PRs generate really cool and meaningful links. |
Getting the title correctly may be a little harder to do. However, I'd assume we can get the
I'm not sure to follow this. Can you expand this and give an explicit example of how it would work, please? |
So these are more scenarios of what can happen with the list: Scenario 1: Some documentation pages got updated (the intended scenario)User modified or added a .md or .rst file: We create a nice little list corresponding to the pages that have been changed such that the user may click directly to the section of the docs that were modified/added. Scenario 2: No changes! (or everything changed or we have no idea)We have built the docs again but actually we don't have any changes to list? Perhaps no files were edited and the documentation is completely unchanged, so we shouldn't "disturb" the PR reader with links? Perhaps a configuration file was edited but nothing detectable changed? Perhaps the footer was changed and everything is updated? Scenario 3: Everything changed!We detect that all pages have changed, perhaps because we correctly see that the footer or configuration or navigation structure is affected. Scenario 4: API docs changedNothing in the documentation pages have changed, but the automatically generated API docs have changes. |
@benjaoming it seems you are describing exactly what we have discussed already in readthedocs/readthedocs.org#8545 This problem is pretty complex to solve correctly for all the users under all these scenarios and that's why we haven't built it yet. Due to its complexity, I do not want to solve this problem on this simple action itself. I think it would be enough for most cases if we can just put the links for all the pages matching documentation files modified in the PR. People will always have the link to the index itself in case they want to dig more on the other pages that may have been modified because of a code change, for example. |
Just noting that:
|
@humitos I believe that conditional builds are different from this issue because here, we are trying to detect the changes post-build while #8545 tries to detect changes pre-build. |
This is not exactly how the GitHub Action works now, tho. We could execute the action only after the build has finished and succeeded. However, in that case, I'm not sure what extra information will we have available in that case currently: there is no API that exposes what files have changed in the documentation output or similar. How are you thinking that post-build will give us more useful data here? |
Sorry I should have presented that (wrong) assumption earlier. In this case, it's much more like #8545. I like the idea of solving these two issues at the same time, both predicting when to build and what URLs will change. There's a lot of developers'+server time to be won if we can get our predictions right in >90% of cases. |
Hi hi! This would be useful for Python PEPs repository as well as the Python devguide, where this would make the reviewer process easier by eliminating the need to navigate to the specific PEP/page that has been modified in the PR! If this is something where all the information needed to detemine the relevant URL is already available (or something you'd be OK having explicit configuration for), that would be useful to know since someone (maybe me) from the community could contribute the logic change for that. :) |
Some of the relevant information is present, but some of it has to be explicitly defined by the user setting up the GHA I'd say. GHA provides the files that were modified in the repository (e.g. using That logic will depend on the doctool used (MkDocs, Sphinx, Docusaurus, etc) and also on the options specified in the doctool itself (e.g. "pretty URL" --ending with I don't think I will have the time to prioritize this work sooner, but I'd be happy to help with reviews 🧐 and directions |
We start talking about a potential implementation for this feature at readthedocs/readthedocs.org#11507. I'd love to have your feedback. |
File Tree Diff is already implemented and we are testing it in our own docs. You can see an example at https://docs--11751.org.readthedocs.build/en/11751/ that comes from this PR readthedocs/readthedocs.org#11751 We should be able to use the same API endpoint (or similar) to fetch that data and insert it into the PR's description. |
We could detect there were changes to specific files (via #3) and insert direct links to those documentation pages as well. For example, if the file
docs/page/section.rst
was modified, we could insert the linkhttps://readthedocs-preview--1.org.readthedocs.build/en/1/pages/section.html
There are some notes to mention:
docs/
from the filename)/pages/section/
or/pages/section.html
)The text was updated successfully, but these errors were encountered: