我在我们的软件中有一个错误,当我收到连接超时时发生。这些错误是非常罕见的(通常是当我的连接被我们的内部网络丢弃时)。我怎样才能人为地产生这种效果来测试我们的软件呢?
如果重要,应用程序是用c++ /MFC编写的,使用CAsyncSocket类。
编辑:
我尝试使用一个不存在的主机,我得到套接字错误:
无效的参数
我的下一个尝试是使用Alexander的建议,连接到不同的端口,例如81(在我自己的服务器上)。这很有效。与断开连接完全相同(等待60秒,然后出错)。谢谢你!
我在我们的软件中有一个错误,当我收到连接超时时发生。这些错误是非常罕见的(通常是当我的连接被我们的内部网络丢弃时)。我怎样才能人为地产生这种效果来测试我们的软件呢?
如果重要,应用程序是用c++ /MFC编写的,使用CAsyncSocket类。
编辑:
我尝试使用一个不存在的主机,我得到套接字错误:
无效的参数
我的下一个尝试是使用Alexander的建议,连接到不同的端口,例如81(在我自己的服务器上)。这很有效。与断开连接完全相同(等待60秒,然后出错)。谢谢你!
当前回答
我过去曾使用过一些策略来模拟网络问题;
拔出网线 关闭你的机器和“目标”机器之间的开关(理想情况下,计算机插入的开关仍在供电,以便机器保持“网络连接”) 在目标计算机上运行防火墙软件,以静默方式丢弃接收到的数据
其中一个想法可能会为您提供一些人为生成所需场景的方法
其他回答
我过去曾使用过一些策略来模拟网络问题;
拔出网线 关闭你的机器和“目标”机器之间的开关(理想情况下,计算机插入的开关仍在供电,以便机器保持“网络连接”) 在目标计算机上运行防火墙软件,以静默方式丢弃接收到的数据
其中一个想法可能会为您提供一些人为生成所需场景的方法
Depending on what firewall software you have installed/available, you should be able to block the outgoing port and depending on how your firewall is setup it should just drop the connection request packet. No connection request, no connection, timeout ensues. This would probably work better if it was implemented at a router level (they tend to drop packets instead of sending resets, or whatever the equivalent is for the situation) but there's bound to be a software package that'd do the trick too.
有很多好的答案,但最干净的解决方案似乎是这项服务
https://httpstat.us/504?sleep=60000
您可以配置超时时间(最多230秒)和最终返回代码。
您可以尝试在外部端口(例如200)上连接到一个知名的Web站点。大多数防火墙都在DROP模式下工作,它会为你模拟超时。
您可以安装Microsoft Loopback驱动程序,它将为您创建一个单独的接口。然后,您可以在它上连接到您的某些服务(您自己的主机)。然后在网络连接中,你可以禁用/启用这样的接口…