data:image/s3,"s3://crabby-images/2bc14/2bc145c3e348511750daf1e6ca6cf5496c61dd01" alt="log file in Selenium"
Hello welcome to Selenium Tutorials, in this post we will see how to create log files in selenium webdriver
In Automation, reporting plays an important role so we can generate the different type of HTML reports, XSLT report, Log files etc.
If you want to create enhanced report and with log attached to HTML report you can use extent report (I use this report) as well
Here is the YouTube video for the same
What is Log File?
The log file is a just simple file, which keeps track of the record or event or info when any event happens or any software run. This whole process is known as logging. We can create a log file as simple log file as well as HTML format.
Note- Any file whose extension is .log will be considered.
Sample Log file
1- Simple log file in text format
data:image/s3,"s3://crabby-images/1a2c8/1a2c8620e14c15aacfe0dadbcc382b27c71811e8" alt="log file in Selenium"
2- Log files in HTML format
data:image/s3,"s3://crabby-images/48426/48426f59d435367d4ebb09a0519e5a38a754fdcb" alt="how to create log files in selenium"
Why is it required in Selenium?
We can create a log file for our simple script also so we can track or debug our script easily if anything goes wrong in the script. For example, if our script is failing at some point then we can track back what went wrong.
What is log4J- Log4j is free open source tool given by Apache foundation for creating log files It helps us to generate a log file in various output target.
How to create log files in selenium
Step 1- Download log4j jar file
Click on the link to download http://mirrors.ibiblio.org/pub/mirrors/maven/log4j/jars/log4j-1.2.15.jar
Step 2- Add log4j to your current project
Select your project > Right click > Click on build path> Click Configure build path> Go to library section > Add external jar file > select the log4j > click on save
Step 3- Open notepad and copy the below code and save the file as log4j.properties.
Note- Please create the log folder inside home directory and while saving use “” to save file
// Here we have defined root logger log4j.rootLogger=INFO,CONSOLE,R,HTML,TTCC // Here we define the appender log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.R=org.apache.log4j.RollingFileAppender log4j.appender.TTCC=org.apache.log4j.RollingFileAppender log4j.appender.HTML=org.apache.log4j.FileAppender // Here we define log file location log4j.appender.R.File=./log/testlog.log log4j.appender.TTCC.File=./log/testlog1.log log4j.appender.HTML.File=./log/application.html // Here we define the layout and pattern log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout log4j.appender.CONSOLE.layout.ConversionPattern= %5p [%t] (%F:%L)- %m%n log4j.appender.R.layout=org.apache.log4j.PatternLayout log4j.appender.R.layout.ConversionPattern=%d - %c -%p - %m%n log4j.appender.TTCC.layout=org.apache.log4j.TTCCLayout log4j.appender.TTCC.layout.DateFormat=ISO8601 log4j.appender.HTML.layout=org.apache.log4j.HTMLLayout log4j.appender.HTML.layout.Title=Application log log4j.appender.HTML.layout.LocationInfo=true
Once you save file it will look like
data:image/s3,"s3://crabby-images/aa154/aa154dfba4e9edf018d55620712b50fdf81e86be" alt="how to create log files in selenium"
Step 4- Write test case
import java.util.concurrent.TimeUnit; import org.apache.log4j.Logger; import org.apache.log4j.PropertyConfigurator; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.firefox.FirefoxDriver; public class Google { public static void main(String[] args) { // Here we need to create logger instance so we need to pass Class name for //which we want to create log file in my case Google is classname Logger logger=Logger.getLogger("Google"); // configure log4j properties file PropertyConfigurator.configure("Log4j.properties"); // Open browser WebDriver driver = new FirefoxDriver(); logger.info("Browser Opened"); // Set implicit wait driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS); logger.info("Implicit wait given"); // Load application driver.get("https://www.google.co.in/"); logger.info("Url opened"); // type Selenium driver.findElement(By.name("q")).sendKeys("Selenium"); logger.info("keyword type"); } }
Step 5- Execute your test case and verify the output and log files as well
Finally, here are three different log files.
data:image/s3,"s3://crabby-images/d2936/d29361af5eb68d79f8f24029756ff645530ae92f" alt="how to create log files in selenium"
Kindly Share this post with more friends and Spread the Knowledge
For More updates Learn Automation page
For any query join Selenium group- Selenium Group
Hi Mukesh,
good ,i am beginner is selenium but you explain very well about loggers. My question is that can we make excel file of log instead of normal text file??
Hi excel is preferred for test data not for logs.
Hi Mukesh Sir,
Will the above steps in “How to create log files in selenium” will solve in linux machine ??
Hi Saran,
Yes, this will work in linux environment too.
Hi Mukesh,
Is it possible to catch test steps, results into log file without calling log in test steps
Hi Rajesh,
Yes, it is possible using Listeners. You can use either TestNG listeners or WebDriverEventListener or both as per your required granularity.
I left the same comment under your video about how to generate log files. In case you see this first please help.
Mukesh, thank you a lot. I am learning like in a good school from you. Would you know how to add clickable line # in Intelije? I used the same and tried other log4j file content and I am getting this:
0 [main] INFO RandomPractice – Google is launched
17 [main] INFO RandomPractice – Search field is located
143 [main] INFO RandomPractice – Hare Krishna is entered
2126 [main] WARN RandomPractice – Searching for the entered text
Whereas I am aiming for getting what you have in the video. I ‘ve heard Inlelije works differently. I have my “log4j.properties” file, may be you can advise what I can add to get the clickable line # or may be there is another way. So far after going to so many blogs, I haven’t figured that out. Thank you very much. All the best to you!
Hi Krishna,
Please check this link https://www.jetbrains.com/help/idea/setting-log-options.html
contents are not overriding
Hi Nikita,
Kindly use log4j.appender.S.Append=false in log properties file
I have implemented this and its working fine but I want to override the existing log file whenever I run the code but currently it appends the new logs in the previous log file
Hi Sourabh,
Add log4j.appender.LOGFILE.Append=false into your log4j.properties and let me know.
Hi,
I am getting this
log4j:ERROR Ignoring configuration file [Log4j.properties].
log4j:WARN No appenders could be found for logger
log4j:WARN Please initialize the log4j system properly.
Hi Suyush,
These messages come because log4j has not been implemented fully. As of now, it is fine. Just check whether you are getting logs properly or not…
Add this line and the issue will be fixed:
BasicConfigurator.configure();
Place log4j.properties file under resources folder.
Hai Mukesh,
Im starter in automation selenium, ur posts are very useful for step by step procedure..Thanks for ur effort..
Hi Divya,
Thanks for your appreciation.
Wonderful Video Article on Log generation in Selenium. Thanks a ton !!!
Thanks Debanjan 🙂 I am glad you liked all concepts.
Very helpful and easy to follow.
Thanks so much!!!
Hi Sanjay,
I am happy to see that my post helped you to implement your requirement.
Hi Mukesh,
Very helpful post for generating logs. I have a question that when the code in eclipse is big enough, it is tedious job to write logger.info(“”); statement after every line. Is there a way out?
Hi Shalaka,
As of now this is the real way to implement log file. For your simplicity, create a method which accepts arguments for logging as parameter.
hey mukesh..
how can i do logging in selenium webdriver using python binding?
Hi Falak,
I never worked much in python. Apologies for not helping you.
Mukesh how do we configure properties file for Log4j, because it varies for project to project. Is there any site we can learn from
Hi Nikhil,
Could you please explain your scenario.
Hi,
How to resolve the error:” Unable to instantiate the class[org.apche.log4j.patternLayout]”
Hi Nirupa,
Kindly go through advance logs with HTML reports http://learn-automation.com/advance-selenium-reporting-with-screenshots-2/
Hi Mukesh.
I have tried to generate logs its generating in console only not into file.
When i tried to save save log4j.properties file with double quotes its saved as log4j.properties not like log4j.
Please help me in this.
Hey Chandrika,
You can try this advance logs with good reporting http://learn-automation.com/advance-selenium-reporting-with-screenshots-2/
Hello Mukesh sir,
How to use debug,fatal,error,warn methods in log4j.
Hi Siva,
you can use in below manner
logger.info(“Url opened”);
logger.debug(“Url opened”);
logger.error(“Url opened”);
Mukesh very good explananation. How do we learn how to configure log4j properties file?
Also what is this line meaning – PropertyConfigurator.configure(“Log4j.properties”);
It means we are specifying the file where all settings are defined.
Hi Mukesh
Very nice Explanation. Thank you . I have one doubt . I have used Logger.info in my selenium script and it works fine when I run in local eclipse. But when I run the same program in jenkins , it gives warning for Logger File. Why the same Logger configuration didnt work in Jenkins ?
Hi Pratikshya,
Ideally it should not give any warning. Have you tried with advance report http://learn-automation.com/advance-selenium-reporting-with-screenshots-2/
hi mukesh,
I am using extent report with attach screenshot but how can I specify the path of failure screenshot.
screenshot like gmail.08082016121213.png
it will be generating at failure time and how, I want to take that one’s path as specify in report path
Hi Suresh,
I covered the same in below post
http://learn-automation.com/advance-selenium-reporting-with-screenshots-2/
Hi Mukesh, Thanks for your valued contribution to the tech community.
Kindly provide a tutorial on new backlog. Thanks
Hi Ajay,
Thanks . Can you please explain for more about backlog tutorial ?
Sorry it was LogBack logger….
http://logback.qos.ch/
how can i append the error code in exception block to the log file. logger.info is not working in catch block.
Hi Ganesh,
I would recommend please use extent report.
http://learn-automation.com/advance-selenium-reporting-with-screenshots/
how to generate a new report every time when i run a program because its showing all previous reports.
Hi ganesh,
use extent report in this case.
Where we have to copy the file? what is home directory?
Hi Sireesha,
Home directory mean where project resides.
To get home directory Right click on project > Click on properties > get the location
I want to genrate seprate log files for these indepent pice of code
Hi Prasanna,
In this case try extent report with Logs http://learn-automation.com/advance-selenium-reporting-with-screenshots-part-2/
Explained very well. Excellent teaching method.
Thank you so much for sharing.
Thank you Ratna 🙂
Hi Mukesh
Right now I am unable to download the log4j jar file from the above mentioned url given by you.
Can you please check this once.
Hi Sid,
Thank you for correcting. Please find below link for jar
https://logging.apache.org/log4j/1.2/download.html
I would recommend for extent report which create advance logs https://www.youtube.com/watch?v=dBj7pxhZXhY
very helpful videoas . thanks a lot . please can you explain about how to automate when the images in the application keeps moving.” http://store.demoqa.com/” website link
Hi Pooja,
Thank you.
Can u please explain your requirement in brief? Do u want to check the image presence or url of images ?
awesome Explanation …….
Thanks Rahul 🙂
Hi Mukesh,
I am following you from last 2 weeks and i found your blog very useful,completely different from other one.
Keep posting new things and make the people know more 😛
HI Prabhakar,
Thank you so much. Keep visiting I have so many post in pipeline.
Where do you save the log4j.properties, i mean what folder does this needs to be saved to
Home directory
Thanks it worked for me…able to see logs for console,text and html.
Cheers Shubham
HI Mukesh I want to store the logs in excel file .please tell me how to do this.
Hi Yeswanth,
I will suggest you not use excel for logs.
Hello Mukesh,
I am using maven and try to save the log results in log file. Results are printing on console but not same in log files files: Following is the console out put.
————————————————————–
Dec 10, 2015 11:58:13 AM pageTests.log4j main
INFO: Browser Opened
Dec 10, 2015 11:58:25 AM pageTests.log4j main
INFO: Implicit wait given
Dec 10, 2015 11:58:25 AM pageTests.log4j main
INFO: Url opened
Dec 10, 2015 11:58:28 AM pageTests.log4j main
INFO: keyword type
—————————————————————-
How can I save logs under log file in maven. I have log4j included dependencies in pom.xml file.
—
Rajiv
Hi Rajiv,
Can u please share the log4j property then I can check the exact issue.
I would recommend to use extent report which have log with report itself.
Give a try http://learn-automation.com/advance-selenium-reporting-with-screenshots-part-2/
How can I catch an error using this. I’m hitting or using the Firefox driver with C#. What is happening for me is that my tests run successfully in Visual Studio or from a command line outside of our TFS Build process, but during the build, the same test case keeps failing. I’m able to capture a screenshot on error, but it isn’t very helpful.
I’d like to see if a control can’t be found, it times out, etc. Would this be the tool for me.
Any help to catch errors in the log if this tool will work for me would be greatly appreciated!!
Hi Matt,
I have not worked on C# so not sure can you please check below link http://www.toolsqa.com/selenium-webdriver-tutorials-in-c-selenium-tutorial-in-c/
its works thanks a ton MUKESH OTWANI
Great Cheers Prem 🙂
Hi there, just became aware of your blog through Google, and found that it is really informative. I’m going to watch out for brussels. I’ll be grateful if you continue this in future. A lot of people will be benefited from your writing. Cheers!
Thank you 🙂 Yes will continue with the same.
Nice post. I was checking continuously this blog and I am impressed! Extremely useful info particularly the last part 🙂 I care for such information much. I was seeking this certain information for a long time. Thank you and best of luck.
Thanks 🙂