This post is a summary of years of my experience using Jekyll and Github Pages. I have seen too many errors in these years. I had to face one just yesterday. I thought maybe others are facing this kind if issues as well. So I’m writing this article on how to deal with it.
Why page build errors happen?
Page build error happens for a number of reasons. A missing HTML tag, missing CSS curly brackets, missing endfor or endif liquid syntax, markdown syntax error and sometimes even for using a tab instead of space in _config.yml file!
- Why page build errors happen?
- The first thing to do when an error happens.
- How to identify the error
- Initial check for page build error
- Exclusion method
- Conclusion
Usually, page build error happens when you push a new post or you change the design of your blog. Sometimes page build error happens just after a simple change and you have no idea what went wrong.
The first thing to do when an error happens.
There is nothing to panic over a page build error because your site will retain its last push but will not allow any more change to happen until you solve the error.
This is where people mess things up. They assume that the last commit was the reason and they may reset the branch to the previous commit. This will solve the problem if your last commit had error but what if your last one isn’t the culprit?!
What if you are using something that is deprecated? So in such cases, it is a little hard to figure out what went wrong. But do not try to change too many things like I did one time which caused this downtime.
How to identify the error
Github sends you an email in most cases when a page build error happens. Most of the times it will have the details on what went wrong. If you do not receive one then you can check the settings page in your website repository for any error messages.
I’m posting some of the emails I have received over the years
Markdown syntax error:
CSS error:
Liquid syntax error:
Symlink error:
Config error after Jekyll 3.0 update:
If tag error:
Syntax highlighter error:
Finally the most frustrating error,
Generic Jekyll build failures:
The page build failed with the following error:
Page build failed. For more information, see https://help.github.com/articles/troubleshooting-github-pages-build-failures.
For information on troubleshooting Jekyll see:
https://help.github.com/articles/troubleshooting-jekyll-builds
If you have any questions you can contact us by replying to this email.
If the email does not specify the error then you are on your own! This is what I received last time. It doesn’t have much information.
I thought it was because I pushed a new post. But even after removing that post, the error existed. While pushing that article, I also changed few design elements. I changed all of them back to normal, but there was no success.
Initial check for page build error
Step 1: Check if the last post has any markdown syntax error.
Step2: If you have made any recent CSS changes then check whether you have any curly braces or semicolons missing.
Step3:
If you have edited html or liquid syntax then check whether any tag is missing. Many times we forget to add </div>
, {% endfor %}
, {% endif %}
. Check this article for all kinds of errors possible.
Step 4:
Check if a new version of Jekyll is released. Last time when Jekyll 3.0 was released, many jekyll sites using realtive_permalink
got such page build errors because it was deprecated. Even for people using highlighter
other than rouge got an error.
If none of these work for you then you should try the next method called exclusion method(or I call it so).
Exclusion method
Jekyll site is basically divided into Homepage, Pages, Posts and sometimes Collections. We exclude one by one in order to check which part is throwing an error. As long as the error goes away, Github will not make any changes to your site.
Backup
While performing exclusion method, you may mess up the content of your local repository. It is better to keep a backup of the whole repository in a different location.
Step 1:
Remove all the content from index.html
or index.md
in the root directory. Push changes to check if you see any error. If no error then you can easily find it inside index.html
file.
Step :2:
Remove all the content from page.html
in _layouts folder. Now push the changes to see the errors are solved.
Step 3:
Do the same for post.html
. If you observe an error then move to step 4. If the error is gone then revert the changes and target posts.html
. Now remove {{ contents }}
from post.html
and push changes. If you get no error then the problem is with posts. You should check individual posts. If you receive an error then posts are alright but something in the post layout is not right.
Do similar process for all the content in your post layout till you get no error and then once you come down to an element which is wrong, see why that is happening.
By using this method I cornered this piece of code causing the problem
I’m not sure why the error happened for a code which seems to be valid. But anyway, I changed it to
That solved the error!
Conclusion
Page build errors are pretty common for beginners. When you get those, you should try to find the root cause. That’s how we learn to code better. I wish Github had more targeted ways to find the error and inform its users. That might take long but for now, we have to solve such problems on our own. Also, keep an eye on the latest releases by Jekyll.
If you have any suggestion, then please leave it in the comment section.
Thanks for reading!