Using the PowerShell Test-NetConnection Cmdlet on Windows

by Adam Bertram Posted on July 26, 2016

Before the days of PowerShell Test-NetConnection, we had many different command-line tools we could choose from to troubleshoot various network connectivity issues. We had ping for testing ICMP echoes and replies; tracert to see where our packets might be getting dropped; nslookup to perform DNS queries against our DNS servers; telnet to check for open TCP ports; and various other utilities. There was a utility for everything.

With the introduction of PowerShell v4 on Windows 8.1 and Windows Server 2012 R2, this single-utility-for-a-single-task approach to troubleshooting connectivity problems has become obsolete. Allow me to introduce you to the new, all-powerful cmdlet that is PowerShell Test-NetConnection. Think of PowerShell Test-NetConnection as ping, tracert, nslookup, telnet and a few other utilities wrapped up into one suite of troubleshooting goodness.

How to Troubleshoot a Network Connectivity Problem with Test-NetConnection

Let's see what we can do with the PowerShell Test-NetConnection cmdlet and look at how we can use it when we're in the unfortunate position of troubleshooting a network connectivity problem. To demonstrate this, I'm going to use PowerShell Test-NetConnection to troubleshoot a common, real-world problem: "I can't get to XYZ website!"

Related: How to Use Scheduled Tasks to Automate File Transfers

What most users don't know is that successfully rendering a website in a browser is, itself, an amazing feat considering the number of moving pieces that have to work together to make that happen. At a minimum, the process entails:

  • Having an internet connection.
  • Having a route to your DNS server.
  • Contacting the DNS server to resolve the URL.
  • Having a route to the IP address the URL resolves to.
  • Having TCP port 80 open.
  • et cetera, et cetera ...
 

Step 1: Confirm Your Connection with Test-NetConnection

To begin troubleshooting, you'll first need to confirm that you have an internet connection. You can do this by simply running PowerShell Test-NetConnection with no parameters at all. However, if you'd like to get more information, I suggest using the InformationLevel parameter with the Detailed argument.

Test-NetConnection -InformationLevel Detailed

This simple command checks your local connectivity, Internet connectivity and that your DNS client can resolve names directed at your DNS server all in one shot.

This simple command checks your local connectivity and internet connectivity and confirms that your DNS client can resolve names directed at your DNS server all in one shot. Consider it a general health check for your network connection. This command checks three of the five processes needed to render a website in one fell swoop!

Step 2: Test-NetConnection to check the Website Host

We'll now need to direct our troubleshooting to the website host in question. Let's use google.com as an example. We can use Test-NetConnection with the ComputerName parameter to simultaneously ensure that the website host can be resolved in DNS, that there's a TCP route available to get to the IP address that the name resolves to, and that it can be pinged.

Test-NetConnection -ComputerName google.com

Directing our troubleshooting to the website host in question.

Even though this step technically verifies we have a route to the google.com web server, I want to find more detailed information about which routers my packets are flowing through to get to the google.com web server. To do that, I'll use the TraceRoute parameter to get a list.

Test-NetConnection -ComputerName google.com -TraceRoute

Using the TraceRoute parameter to get a list.

Step 3: Ensure That Your TCP Port Is Open

Our final test is to ensure that the TCP port we're expecting the web server to be running on is open. In this case, since we're just specifying google.com, I'm going to assume it is TCP port 80. To do that, we'll simply add another parameter to Test-NetConnection. Because Test-NetConnection understands the standard TCP port for a few different services, we don't even need to know the port number. I can just pass HTTP to the CommonTCPPort parameter and it will do the work for me.

Test-NetConnection -ComputerName google.com -CommonTCPPort HTTP

Ensure that the TCP port we're expecting the webserver to be running on is open.

However, if the website might be running under a different port, such as 8080, you can specify a TCP port directly by using the Port parameter instead.

Test-NetConnection -ComputerName google.com -Port 80

We've now tested each of the connectivity requirements outlined at the start of this article. If we still can't render the website at this time, we've confirmed the problem does not lie with our client, and we can pass the problem on to Google or perhaps a downstream DNS server. Don't stop here; read our eBook, "How to Automate Using PowerShell," for other PowerShell tricks.

Related Articles

PowerShell Scripting and Open Management Infrastructure (OMI)

How to Use PowerShell Copy-Item Cmdlet to Transfer Files Over WinRM

Leveraging PowerShell Automation in the Cloud

How to Use Scheduled Tasks to Automate File Transfers

 

Adam Bertram

Adam Bertram is a 25+ year IT veteran and an experienced online business professional. He’s a successful blogger, consultant, 6x Microsoft MVP, trainer, published author and freelance writer for dozens of publications. For how-to tech tutorials, catch up with Adam at adamtheautomator.com, connect on LinkedIn or follow him on X at @adbertram.

More from the author

Related Tags

Related Articles

Continental Ditches Scripts and Automates File Transfer
Continental Automotive is one of the world's leading automotive suppliers, employing over 215,000 people in 55 countries. With five divisions and a global network, Continental has a lot of data to transfer between several thousand internal and external customers,...
Leveraging PowerShell Automation in the Cloud
As part of this cloud transition, it's important to realize that even though you can't see a system it still needs to be managed. Let's talk about PowerShell automation.
Prefooter Dots
Subscribe Icon

Latest Stories in Your Inbox

Subscribe to get all the news, info and tutorials you need to build better business apps and sites

Loading animation