Note: only the latest version is supported
Hi , So far the test ng documentation looks like that of 80s. A new documentation portal is much required which shall have following benefits
and much more
cc: @krmahadevan
@freakerhere - Thanks for following up on this.
Are you willing to open up a PR for this ? We can start off with a very small change to get a feel of how the new UI would look like and perhaps take it from there ?
@email2vimalraj - I remember we spoke on similar lines as well. Care to chime in?
@juherr @cbeust - What is your thoughts on giving a new face lift to our documentation portal ?
Always happy to brainstorm about better documentation but I'd like the discussion to be more focused.
For example, specifically, what kind of information is missing? What are the suggestions to make that data easier to find?
Hi Krishnan,
Thanks for bringing me to this conversation. My idea is to use the markdown
files to create contents which will automatically produce HTML files and
can be served through our hosting provider. I’m thinking of using GatsbyJS
with our own simple UI design.
Also can leaverage GitHub actions to build and deploy automatically
whenever the content is updated in GitHub.
Please let me know what you think.
Thanks
Vimalraj
@email2vimalraj - In terms of look and feel and the overall approach, do you think you could perhaps show a small demo implementation ? That could perhaps add more visibility into your proposal. Also it would be great if you could also list out what are the prerequisites in terms of software / libraries etc., that need to be installed in order to support this.
@cbeust What are your thoughts ?
Fyi, the documentation is already served by Github Pages.
So you can directly write markdown and the file will be translated.
Yes will share a prototype this weekend.
Julien, so that means, testng.org is mapped to GitHub pages?
Thanks
Vimalraj
@juherr
Fyi, the documentation is already served by Github Pages.
So you can directly write markdown and the file will be translated.
I was under the impression that in order for github to serve documentation, the changes should be available in a special branch called gh-pages
. But that doesn't seem to be the case in our project. I also remember us having to run a hook after a change has been published to the TestNG repository, so that it can get reflected in the testng.org site.
Julien, so that means, testng.org is mapped to GitHub pages?
Correct: https://github.com/testng-team/testng-team.github.io
Are we talking about just changing the way the doc looks or rewriting the doc? I'm confused.
@cbeust
There are a couple of things that are being discussed here.
So we are more talking about changing the way the documentation looks like and not necessarily re-writing the doc (which is not needed because the content is valid as of today).
@cbeust
There are a couple of things that are being discussed here.
- Structuring of content is being asked by @freakerhere - I believe you asked some follow up questions for which @freakerhere is to be getting back.
- Look and feel. I got @email2vimalraj involved because we both have been discussing of ways in which we can improve the overall look and feel of the testng documentation portal (Maybe have it revamped to look similar to https://jcommander.org ) and we are bouncing back ideas. The documentation portal to the best of my knowledge is up-to date in terms of content (there may be a miss here and there) but maybe we could relook at how we can help people find information by restructuring it (I personally liked how the jcommander site looks like).
So we are more talking about changing the way the documentation looks like and not necessarily re-writing the doc (which is not needed because the content is valid as of today).
@krmahadevan content wise the portal is ok.
@cbeust
But my major point/feedback are
For PR i am very much available but lack experience and need someone to guide and mentor me for a head start.
hey there ,
i have made read the docs portal with same content as test-ng .here is the link
http://testng-docs.readthedocs.io/
Let me know how i can push the code to this repo .
Thanks,
Yatheesh
@cbeust @juherr WDYT ?
This looks fine to me, but there's a lot of work to carry the existing doc to that format. I'm open to doing this, though, it will modernize the look.
Let's start with the basics: how do you build this doc, @yatheeshraju?
Also, we should probably move this issue to https://github.com/testng-team/testng-team.github.io, which is where the work will be taking place.
@cbeust
i am using https://www.mkdocs.org/ for building markdown(.md) files to the website.
is the theme i am using https://squidfunk.github.io/mkdocs-material/ .
Read the Docs does all the heavy lifting http://readthedocs.org/
we push the markdown files to github and Read the Docs builds the docs from github repo .
I am also new to it .only followed some basic tutorial .
i have converted most of the docs to the format .
@cbeust
Also, we should probably move this issue to https://github.com/testng-team/testng-team.github.io, which is where the work will be taking place.
Agreed. But since the conversation has started here, lets use this issue to finalize and then have an issue created in the documentation project once we have decided on the approach. that way the conversation is all in one place.
@yatheeshraju - It looks like readthedocs.org suggests that it would be doing the hosting of the documentation and I also noticed that the URL also changes. So how do we take care of ensuring that we retain the url as testng.org
?
@email2vimalraj - FYI. This is how the entire setup is done for the current TestNG documentation.
@krmahadevan in readthedocs admin page we can add custom domain which will make the docs to be served frorm testng.org
if we want to use the current testng-team github repo i can build the mkdocs and provide the static files .they can be hosted from github like the current web pages , so will not change the current setup .
Hello All,
Here are my observations which might help to make decisions:
Gatsby:
Gatsby
is a framework which helps to build a static site. That means we can build the full-fledged website with documentation page where a typical documentation like site would look like. And moreover, gatsby is built using latest technologies like React and GraphQL. My idea is to build a landing page and docs page. Example of landing page and docs page: https://www.gatsbyjs.org/ - A gatsby website itself.
UI designs will be built using React and docs will be rendered from markdown files. For UI design, the templating is very simple because it is mostly HTML and we easily get contribution from the community as it is JS based. This stack (JAMStack) is very popular now a days.
The gatsby has wide variety of plugins which helps to easily configure the SEO, responsive images, offline support, PWAs.
The build will provide the set of static html files which can be either hosted somewhere or check it in github itself to serve using github pages. Publishing through github pages doesn't change of existing workflow.
Mkdocs:
Now the mkdocs
on the other hand is built using Python and helps to develop the documentation site. This doesn't support adding landing pages or any other static pages. It uses the jekyll templating engine to convert the templated html to static html. So we have to learn the jekyll templating language in case customization required. The docs are written in markdowns like gatsby. Mostly we should use the existing themes available in the readthedocs, though you can customize the themes provided by readthedocs, it is limited. There are not much community activities in Mkdocs.
The build and publish steps are pretty much similar to gatsby. Readthedocs may not be necessary in case we use github pages.
Now come to some statistics:
Trend analysis: https://www.npmtrends.com/gatsby-vs-mkdocs
Stack comparison: https://stackshare.io/stackups/mkdocs-vs-gatsbyjs
My Verdict: I go for gatsby mainly because of vibrant community and very active in development. Also, it provides full control to the developer to customize however we want.
Hope this helps to make a decision and move forward.
@yatheeshraju Regarding this docs:
Is there a way to view the entire documentation in one page? I think this is important for the reasons mentioned here. Second paragraph. I also include the text here for convenience:
For online documentation, make sure that there is a link that brings up the entire documentation in one HTML page (put a note like "monolithic" or "all-in-one" or "single large page" next to the link, so people know that it might take a while to load). This is useful because people often want to search for a specific word or phrase across the entire documentation. Generally, they already know what they're looking for; they just can't remember what section it's in. For such people, nothing is more frustrating than encountering one HTML page for the table of contents, then a different page for the introduction, then a different page for installation instructions, etc. When the pages are broken up like that, their browser's search function is useless. The separate-page style is useful for those who already know what section they need, or who want to read the entire documentation from front to back in sequence. But this is not necessarily the most common way documentation is accessed. Often, someone who is basically familiar with the software is coming back to search for a specific word or phrase, and to fail to provide them with a single, searchable document would only make their lives harder.
I don’t entirely agree to a single page documentation with given the latest
technologies available to overcome the limitation you pointed out. The
algolia docsearch could be used here to enable the search across pages,
more here:
https://community.algolia.com/docsearch/. Please note that this is entirely
free for the open source.
And on another note, think of SEO capabilities, if it is a single page,
then SEO might not crawl properly with certain keywords. If it is multiple
pages with proper titles, then SEO can easily crawl page by page and users
can often search directly from search engines.
Please let me know what you think.
Thanks
Vimalraj
@yatheeshraju Regarding this docs:
Is there a way to view the entire documentation in one page? I think this is important for the reasons mentioned here. Second paragraph. I also include the text here for convenience:
For online documentation, make sure that there is a link that brings up the entire documentation in one HTML page (put a note like "monolithic" or "all-in-one" or "single large page" next to the link, so people know that it might take a while to load). This is useful because people often want to search for a specific word or phrase across the entire documentation. Generally, they already know what they're looking for; they just can't remember what section it's in. For such people, nothing is more frustrating than encountering one HTML page for the table of contents, then a different page for the introduction, then a different page for installation instructions, etc. When the pages are broken up like that, their browser's search function is useless. The separate-page style is useful for those who already know what section they need, or who want to read the entire documentation from front to back in sequence. But this is not necessarily the most common way documentation is accessed. Often, someone who is basically familiar with the software is coming back to search for a specific word or phrase, and to fail to provide them with a single, searchable document would only make their lives harder.
@drapostolos
No we do not have option to view entire document as one page ,
full docs
we have a search option .
@cbeust @krmahadevan @juherr kindly let know about your thoughts
@yatheeshraju
if we want to use the current testng-team github repo i can build the mkdocs and provide the static files .they can be hosted from github like the current web pages , so will not change the current setup .
Can you please call out the steps that anyone who wants to contribute would need to take ?
@juherr / @cbeust - I am not clear on whether the documentation is being served from testng.org (I remember earlier we used to a php backed web hook url, which we had invoke after we get our documentation changes merged into the GitHub repository, for the documentation to get reflected in testng.org. Has this changed ? )
It would be great if you could please call out the current process that is being followed in order for the documentation to be rendered and also help conclude on what should be our way forward ?
We have two options right now.
@krmahadevan No more php server since Cedric had some issues with the hoster. So yes, it changed and it is currently backed by Github Pages.
If I understand well, Gatsby can be backed by GithubPages too.
Both solutions look great and more modern than the current one.
@cbeust you choose! :)
@krmahadevan
contributor system setup
-Python
-mkdocs (pip install mkdocs)
-mkdocs-material (pip install mkdocs-material)
-clone the repo ( currently https://github.com/yatheeshraju/testng-docs. i can commit it to the official testng-docs repo)
-make changes to files (mkdocs serve).To view changes in local system
-commit to publish
Admin side one time setup (contributors need not do this)
-create account in readthedocs
-connect the repo to readthedocs
-in advanced settings -
-choose single verison
-select mkdocs in documentation type
-give requirements.txt in requirements file name .
-in overview you can build the docs from the connected repo.
-in domain settings you can add the testng.org domain to point to it .
I am open to gatsby as well . looks good and customization friendly than mkdocs/readthedocs .
@yatheeshraju - That is awesome detailed information.
@email2vimalraj - Can you please provide the same for Gatsby ?
@krmahadevan : here you go
Contributor setup:
Publisher setup:
Please let me know if you need further details.
Personally, not a fan of forcing contributors to have to install Node, this is going to discourage a lot of people from contributing (not that the TestNG docs change much, but still).
I'd rather have a doc portal where contributors can just clone the team-testng.github.io
repo, edit a few files, commit and push them, and the CI/CD pipeline takes care of building the docs.
+Update+: Added more detailed steps of build and deploy process.
@cbeust : I should have been little clear. For the doc site, we’ve two different types of contributors,
UI contributor:
Doc contributor:
CI / CD workflow:
GH_TOKEN
with the access token as a valuedeploy
script in the package.json
which will build and push the public folder (this folder will contain static htmls) to the gh-pages
branch, since we wanted to serve from the github pages."scripts": {
"deploy": "gatsby build --prefix-paths && gh-pages -d public -r https://[email protected]/cbeust/testng-docs.git"
}
Please notice the GH_TOKEN
environment variable which will be replaced at run-time.
The sample .travis.yml
will look like as below. Travis will trigger the build only when a commit is pushed to master
branch:
language: node_js
before_script:
- npm install -g gatsby
node_js:
- "10"
deploy:
provider: script
script: cd docs/ && npm install && npm run deploy
skip_cleanup: true
on:
branch: master
Hope this is clear now.
@cbeust - Can we please decide on this ?
@vimal: this means that look and feel will be determined by the react code and text/content will be taken care from docs.
But i am still in lingo as to how the two will be coupled?
For example let say i want to add a new section to the documentation for a new feature in that case do i have to work on both parts? or that can be taken care by react. If yes, then we have to discuss on the architecture of the react framework.
it would be helpful if you can create a demo. I am open for help
If the new section involves some UI changes like adding new styles of look
and feel, then yes it requires some react code. If the new section is just
a doc then adding or updating the markdown is pretty much what we need to
do.
For example, you can refer my blog site which I’m working on now:
https://github.com/email2vimalraj/site. I add my markdown in posts folder
and every time I push to master, the site will be deployed automatically to
zeit now - my CDN provider and accessible via https://vimalrajselvam.com
with zero downtime.
This is a typical way for most of the blogs or doc sites backed by Gatsby.
I believe Krishnan’s blog also works in the same way.
Please let me know if you have any questions.
Thanks
Vimalraj
On Sun, 19 Jan 2020 at 9:02 PM, ayush notifications@github.com wrote:
@vimal https://github.com/vimal: this means that look and feel will be
determined by the react code and text/content will be taken care from docs.But i am still in lingo as to how the two will be coupled?
For example let say i want to add a new section to the documentation for a
new feature in that case do i have to work on both parts? or that can be
taken care by react. If yes, then we have to discuss on the architecture of
the react framework.
it would be helpful if you can create a demo. I am open for help—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
https://github.com/cbeust/testng/issues/2219?email_source=notifications&email_token=AAJIRXWNWAO2AS2VXOVBZ2DQ6RFPTA5CNFSM4KC4GERKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEJKRTMY#issuecomment-576002483,
or unsubscribe
https://github.com/notifications/unsubscribe-auth/AAJIRXS7FJQZ7XQNRGDRL7LQ6RFPTANCNFSM4KC4GERA
.>
Thanks,
Vimalraj
@cbeust : Need your input to go ahead.
I already stated my concern previously.
I'd prefer the docs to be editable by just cloning the documentation site, editing a file, and committing. Requiring to install Node concerns me.
Great discussion! Thanks for starting this thread and posting so much of useful information 👍.
I also wanted to share my two cents to change the look & feel of the testng official website which I believe will attract the community to be involved in this wonderful project more than ever 😃.
I have created a basic PoC to present my case here - https://s4ik4t.github.io/
This website is built on Vuepress and deployed via Travis-CI/GitHub Pages automated pipeline (using markdown). Yes, Vuepress has a dependency on nodejs however (as per my experience) for vast majority of the contributors (I'll say 98% 😉) that should not make any difference because they can easily edit the markdown page directly from GitHub without requiring anything else (apart from Pull request approval 😄).
There are other useful customization options (e.g. inbuilt search, SEO etc.) which would be one time activity and I will be happy to contribute to make this happen. Vuepress is a single page application and is built keeping technical documentation in mind.
I would love to know your thoughts regarding this @cbeust @krmahadevan @juherr @email2vimalraj @yatheeshraju @freakerhere
Thanks for testng! Keep rocking and stay safe!
@cbeust Any update? https://s4ik4t.github.io/ looks very nice.