different TLS handshake versions in the ClientHello from the same client    
   I have a python client. Using "ssl.SSLContext()" and "set_ciphers(myciphers)" I can contol the list of the client ciphersuites. The default context disable SSL 2.0 and SSL 3.0 by default and I do not any change to the versions.
I send 3 handshakes to the website using different ciphersuite list in each one. I do not change the version.
In Wireshark, the ClientHello in the "protocol" column, I see different versions? I am contacting the same site. The client does not change the version.
1) Can you please explain to me why I see different TLS protocol version? 2) If this is not the actual version the client offer (which should be TLS 1.2), where can I get the actual client offered TLS version?
Please help!
 
  
 
Wireshark version?
Can you share the capture file, e.g. Cloudshark, Google Drive, DropBox etc?\
Is this what you are seeing?
https://github.com/openssl/openssl/issues/1689
I use Wireshark 2.4.5-1 on Ubuntu 18. The client underlying TLS library is OpenSSL 1.1.0g.
Here is a screenshot. I think I have not saved the capture file but have a screenshot. https://ibb.co/ff3kJz
My questions:
@grahamb@Bob Jones plz advise. I added an (anonymized) screenshot. Hope it explains the problem.
Did you check the link posted? That provides a lot of information related to your questions. In addition, this should as well:
https://security.stackexchange.com/questions/29314/what-is-the-significance-of-the-version-field-in-a-tls-1-1-clienthello-message
Finally, certain cipher suites are defined for only certain versions; for example, TLSv1.2 via RFC 5246 says:
so presumably if you changed from some other suite to one of these, you would now be at TLSv1.2 because they did not exist before, which could be a version change. An expert could probably look at the different suites offered by the client and help you better, but you decided not to provide a trace, as was suggested by @grahemeb.