Golang, some first feeling.

agolangf · · 823 次点击    
这是一个分享于 的资源,其中的信息可能已经有所发展或是发生改变。
<p>I am using golang since some months, mostly for exercise, and after a while I would like to share some balance of this period. I hope a nice discussion can start.</p> <p>I used to develop in C, C++ and ADA95, since I was doing HPC and some part or railways consulting. After I changed becoming an infrastructure person: architecture, WAN, and so on. So i mostly wanted to keep in touch, and learn a modern-design programming language.</p> <h2>PRO:</h2> <p>I&#39;ve to say, is fun. Really. I gave myself a goal, to write a server which provides an NNTP interface and uses P2P to propagate posts and groups. (Useful or not, you need a challenge).</p> <p>It took 3 weeks of my spare time (not so much, then) to develop a NNTP server working with slrn, soup, thunderbird and pan. Amazing. I could release it as a local NNTP server. I am still into the P2P part. </p> <p>Learning curve? Good. Not a single library: I just used go and its libraries, and the NNTP RFCs , and the more I wrote, the more I reused. Amazing. </p> <p>I started to use it as a &#34;c&#34;, only writing functions and passing arguments. Now I am into goroutines, and entering the planet of interfaces.</p> <p>I was missing ADA95 templates for safely accessing data, but I see interfaces here. </p> <p>golang looks like C+++, plus boost, plus some features from ADA. Looks like they did it for me.... :)</p> <p>Joking apart, the fact I could achieve a NNTP server in , like, 3 FTE, was impressive, given i was not programming since years.</p> <h2>CONS:</h2> <p>I think the community should be refocused, or at least improved. Don&#39;t take me wrong, I am not willing a fight. But.</p> <p>Ok, golang has pointers, cycles, idioms, and so on. All that basic stuffs are good to study. <strong>At school</strong>. Having 60% of posts around like &#34;how to use struct&#34;, &#34;how to cycle&#34;, &#34;how to pass arguments&#34;, is terrible.</p> <p>It makes people looking for some suggestion to waste time. Like you want to know abou tcp sockets and you are lost in a immense &#34;Hello World&#34; grass field. You should have learn &#34;hello world&#34; at school. </p> <p>I think the community should focus more about what is really the issue of go (interfaces, goroutines, and so) and leave the common things to the school. The schools people is supposed to have before of powering up a computer. At the end, developing is not a kind of welfare supposed to give an income to everyone: is a job. You should have some basic skills before of applying.</p> <p><strong>Another cons is the &#34;<em>dev for the show</em>&#34;. Programming as a new welfare.</strong></p> <p>People writing libraries on github just to have a new line on Linkedin. Not maintaining them, not fixing bugs, and so on.</p> <p>Just an example: We developed a framework in my company. It took a team of business analysts to get a coherent set of use-cases out of 3,000 customers (mostly enterprises: is there another kind of framework user?). Then a team of developers coded and did formal verification. And then a team of technical writers wrote the documentation.It took 2 years.</p> <p>Now, I see single people with no customers, programming alone, to come and say &#34;I wrote a framework last week&#34;. <em>No. Forget it. You don&#39;t.You didn&#39;t . You can&#39;t. End of story.</em> Somebody should stop that. Because other people then will start using those &#34;wannabe-frameworks&#34;. Expecting they are frameworks. And the result will be on newspapers as the &#34;security leak of the year&#34;.</p> <p>The same for libraries. Writing a library is not an easy job. Documentation has to be excellent, since who uses the library should know to invoke the API, but is not sufficient. Should also know when NOT using it, how it performs and its limits. </p> <p>I found a ton of &#34;libraries&#34; which have no documentation at all, just &#34;how to invoke it&#34;. The first version of my program crashed after 11 hours of running, just because the UPnP library was opening UDP sockets and never closing them. And it was logging in chinese. And it was &#34;<strong>THE</strong>&#34; library for NAT-UPnP. Everybody is suggesting this library. I tried to contact the developer and he didn&#39;t answered: he had its line on its linkedin profile, so mission accomplished. So half of the &#34;planet go&#34; is using a NAT UPnP library which crashes after some hours.</p> <p>I went to NAT UDP , at least I see a RFC for that: but still the issue is: once one library is written, everybody is suggesting this library. And there is no rating. <strong>And people is writing them just to enrich their linkedin profiles</strong>. </p> <p>Heartbleed was not enough as a lesson? </p> <p>Too many people is writing their &#34;package&#34; or &#34;library&#34; just to add one line on their resumee , to appear good to the human resources. They throw some bullshit on github, they forget it, and they&#39;re done. One more line on linkedin.</p> <p>So we have a ton of &#34;restful framework for web applications scaling well with rest and mongo/couch in the cloud&#34;. To better hit the top-10 buzzword list, i guess. When I was young we had buzzwords like &#34;fractals, chaos theory, quantum computing and neural network&#34; mentioned: maybe those buzzwords are a bit outdated, but I still see &#34;buzzword-as-a-welfare&#34;. </p> <p>I think the community should react to that, starting to rate libraries and &#34;frameworks&#34;. this &#34;i wrote a framework just because I want to give a talk&#34; or &#34;I wrote a library for my linkedin profile&#34; will poison everything. To find a reliable library is close to impossible right now, and go is at the beginning of its life.</p> <p>Worst , after one library is written, everybody suggests to use this to the others, so no better libraries are developed.The terrible NAT-UpNP library I was using had thousands of forks. One per bug, I guess. Again, heartbleed was not enough as a lesson? </p> <p>Last but not least: golang comes with an impressive amount of libraries. Amazing. Most of people talking of go are talking about pointers, reference, loops, functions... topics which are not go-specific. So you learn to write a routine in the same way you could write in c, java, php and python. <strong>And you don&#39;t get something: there was already some go package doing that. In one line</strong>.</p> <p>Again, I think the community should focus more on go-specific issues. Comparing a language to others is a futile discussion. Answering to people which says &#34;java is faster&#34; is a waste of time. To show how to use crypto libraries which are coming with the go compiler is more, and more, and more interesting. When I was looking around how to truncate a string, I found a load of c-like routines with loops. Then I dig into the go-specific features, and I see a stupid line was enough: but is not c-like, is go-like , and perhaps go-specific. </p> <p>So I think the community is still in time to focus more on go, less in pseudo-framework, pseudo-libraries which are not (neither can be) what they claim to be, and focus on explaining go-specific issues. How to write a &#34;for&#34; statement should be clear much before of starting to program, IMHO.</p> <p>Just my two++ cents.</p> <hr/>**评论:**<br/><br/>slimsag: <pre><p>Your pros seem pretty cool, looks like you got to experience a good amount of the language/ecosystem (and in three weeks, no less!) :)</p> <p>Most of your cons don&#39;t seem to be about Go in specific but more about your perspective (or rather <em>ideals</em>) about software development in general.</p> <blockquote> <p>Ok, golang has pointers, cycles, idioms, and so on. All that basic stuffs are good to study. At school. Having 60% of posts around like &#34;how to use struct&#34;, &#34;how to cycle&#34;, &#34;how to pass arguments&#34;, is terrible.</p> <p>...</p> <p>How to write a &#34;for&#34; statement should be clear much before of starting to program</p> </blockquote> <p>I haven&#39;t seen many articles about that, past maybe Effective Go and example code. Everything I&#39;ve seen is about more advanced Go patterns like channels, goroutines, etc. Also consider that <em>most people</em> are just being introduced to programming, and there should be no requirement on a formal CS background to simply learn how to program -- we&#39;re in the 21st century for a reason: learning can occur in person or online.</p> <blockquote> <p>Now, I see single people with no customers, programming alone, to come and say &#34;I wrote a framework last week&#34;. No. Forget it. You don&#39;t.You didn&#39;t . You can&#39;t. End of story. Somebody should stop that. Because other people then will start using those &#34;wannabe-frameworks&#34;. Expecting they are frameworks. And the result will be on newspapers as the &#34;security leak of the year&#34;.</p> <p>once one library is written, everybody is suggesting this library. And there is no rating. And people is writing them just to enrich their linkedin profiles. Heartbleed was not enough as a lesson?</p> </blockquote> <p>Anybody can write a framework, or library. They can publish it to the internet, and others are allowed to recommend it. We&#39;re not a totalitarian community, nor should we be.</p> <p>The lesson from OpenSSL&#39;s Heartbleed was that people like yourself blindly accept someone else&#39;s code as &#34;correct&#34; <em>when it may not be</em>. If you don&#39;t understand how 100% of OpenSSL&#39;s source code works, then you are <strong>trusting</strong> the person who wrote that code. The same applies to many situations of life.</p> <p>We all want perfect libraries that work for everyone&#39;s use case, but the only way we&#39;re going to get there is by learning from our mistakes and trying <em>a lot</em>. Research your libraries and <em>personally ensure that they do what you want</em>, or else you accept the risk of trusting that the person who wrote them knows what they were doing.</p></pre>Low-Eel: <pre><blockquote> <p>Your pros seem pretty cool, looks like you got to experience a good amount of the language/ecosystem (and in three weeks, no less!) :)</p> </blockquote> <p>Well, the goal was pretty ambitious. I wanted to write innd+bittorrent+dht , and It was fun. When is fun, you dig in. But also, you google a lot. I was a newbie.</p> <blockquote> <p>Most of your cons don&#39;t seem to be about Go in specific but more about your perspective (or rather ideals) about software development in general.</p> </blockquote> <p>100% true. I agree on that. But golang is &#34;special&#34;, because is new. As I wrote, it is still possible to fix this, and make go REALLY different.</p> <blockquote> <p>we&#39;re in the 21st century for a reason: learning can occur in person or online.</p> </blockquote> <p>This is probably the part I don&#39;t agree. getting information and getting education is different. Behind any tecnique there is some theory. Of course you can feel a cowboy and ignore the theory, like people going with perpetual motion. But the theory will make you pay the price. Like, perpetual motion will never work. Sooner or later, the theory you never studied will present you a fee: <strong>you waste time</strong>.</p> <blockquote> <p>Anybody can write a framework, or library. They can publish it to the internet, and others are allowed to recommend it. We&#39;re not a totalitarian community, nor should we be.</p> </blockquote> <p>I am not asking for censorship. One solution could be rating. Like google play have . I won&#39;t say this is sovietic. i would like to write in some places that a library cannot panic a whole program, that a library should close any file descriptor it opens , or have a method to do it, and then this UPnP library is bullshit. But I can&#39;t. And when I asked for suggestions, this was depicted as THE library for NAT UPnP.</p> <p>If you don&#39;t like rating, ok, so we have a <strong>technical</strong> solution already: <strong>formal verification</strong>. I f you want to stay &#34;tecnical&#34;, yes, I ask to provide the golang &#34;testing&#34; feature with <strong>formal verification capabilities</strong>.</p> <blockquote> <p>The lesson from OpenSSL&#39;s Heartbleed was that people like yourself blindly accept someone else&#39;s code as &#34;correct&#34; when it may not be</p> </blockquote> <p>No, the problem was much, much bigger: this SSL library was trusted because , googling around (like you mention: learning online) everybody was telling around &#34;this is the library&#34;, &#34;it comes from OpenBSD people&#34;, and so on. The trust was not a &#34;blind&#34; trust: was a immense BIAS. If anybody was reading almost ALL the literature in the planet, it was telling you &#34;this is safe, this is the best&#34;. Only developers which have ACTUALLY tried to use OpenSSL noticed it was a bullshit of incoherent interfaces. But they had no chance of telling it. Don&#39;t depict the trust being &#34;blind&#34;: there was a shit load of endorsement by &#34;experts&#34; on this library. And <strong>no formal verification</strong>. </p> <p>It is very, very easy to <strong>proof</strong> heartbleed would not have passed a <strong>formal verification</strong> process. So yes, I think I am asking a formal verification tool for go. Yes, it can go.</p> <p>I am not havin &#34;ideals&#34; about development, btw: as a company we are asked to formally verify <strong>everything</strong>. It is business and pretty normal in automotive/railways.</p> <blockquote> <p>We all want perfect libraries that work for everyone&#39;s use case, but the only way we&#39;re going to get there is by learning from our mistakes and trying a lot. Research your libraries and personally ensure that they do what you want, or else you accept the risk of trusting that the person who wrote them knows what they were doing.</p> </blockquote> <p>The easiness of developing in golang makes then useless to use libraries. It was faster to me to write NNTP from scratch than debug someone else library. So, we don&#39;t need frameworks or libraries, only software. Which is a suitable position, don&#39;t take me wrong. </p> <p>If this is the case, why I see people announcing its <em>need-to-be-debugged</em> frameworks <strong>everyday</strong>, when it takes more time to debug than to rewrite from scratch?</p> <p>Good question.</p> <p>What I suggest, exactly?</p> <h2>Being honest, I would see the &#34;testing&#34; feature of golang a bit more powerful, putting <strong>formal verification</strong> in it.</h2> <p>This is the only solution I see, being honest. </p> <p>To see a very good language being covered of bullshit in a few monts is very , very, very sad. Maybe just because I like it.</p></pre>jimuazu: <pre><p>Formal verification would be really interesting. What kind of formal verification tools/languages/etc do you use in other languages? How hard would it be to adapt one of these for Go?</p></pre>Low-Eel: <pre><p>Well, we are mostly using Frama-C with ACSL</p> <p>The issue is more or less this:</p> <p><a href="http://www.adacore.com/knowledge/technical-papers/testing-or-formal-verification-do-178c/" rel="nofollow">http://www.adacore.com/knowledge/technical-papers/testing-or-formal-verification-do-178c/</a> </p> <p>and you can find it here:</p> <p><a href="http://frama-c.com" rel="nofollow">http://frama-c.com</a></p> <p>and for ACSL:</p> <p><a href="http://frama-c.com/acsl.html" rel="nofollow">http://frama-c.com/acsl.html</a></p> <p>As you can see, it is quite a work, if you want to reach 178C, which is , I would say, &#34;a bit too much&#34; for amateur software, :) :) even if, with IoT, I would not wonder if something similar would be requested in the future on all IoT.</p> <p>I tool I prefer (but I am not developing since year, I am mostly into TRAC architecture) is <a href="http://spinroot.com" rel="nofollow">http://spinroot.com</a> </p> <blockquote> <p>How hard would it be to adapt one of these for Go?</p> </blockquote> <p>As far I remember, there is a tool which translates go to C (maybe is the other way around?) but I never went deep in it. Converting go to c would permit to use spin, by example. </p> <p>And also go is high-productivity-oriented, so I can&#39;t say to add such an analytic work.</p> <p><strong>But I can think to port &#34;some ideas&#34; to golang. Not all the framework, just a little piece.</strong></p> <p>What I would like would be something added to the test framework, which permits me to write &#34;comments&#34;, like:</p> <p><code> @@ assert (__net.Conn# == 0 &amp;&amp; __filedesc# == 0) </code></p> <p>meant that in this point we have no sockets open and no files open. Then, when I import a function i can &#34;lock it&#34; like:</p> <p><code>@@ assert (__net.Conn# == 0 &amp;&amp; __filedesc# == 0)</code></p> <p><code>myforward := new(UpNp)</code></p> <p><code>@@ assert (__net.Conn# == 0 &amp;&amp; __filedesc# == 0)</code></p> <p>this would mean that before <strong>and</strong> after this call, I expect there are no file open and no socket open. Then, some test framework could check if this happens or not.</p> <p>This would solve many problems when writing and when importing </p> <p>This is <strong>not a full verification</strong>, neither a verification at all, I am just importing <strong>some ideas I&#39;ve seen</strong>, but could be very very useful: imagine I expect at a certain pont a &lt; 10 and a &gt; 2, just write it as a comment, and some test tool can check if this happens.</p> <p>Just my two cents++, of course.</p></pre>klaaax: <pre><blockquote> <p>Now, I see single people with no customers, programming alone, to come and say &#34;I wrote a framework last week&#34;. No. Forget it. You don&#39;t.You didn&#39;t . You can&#39;t. End of story. </p> </blockquote> <p>edited for politeness purpose, </p> <p>bottom line is , you&#39;re not entitled to anything, and people do not work for you. people use github and co as free hosting for their project. So stop being arrogant because you think you&#39;re a &#34;real programmer&#34;, you must be really a pain to work with, I pity your poor colleagues having to work with a jackass like you . If you find a bug , make a pull request, if you think something is done wrong, then open an issue but don&#39;t come here and complain people are writing software you don&#39;t want,they do it for free. They do that for various reasons and you don&#39;t get to judge them. Seriously , you&#39;re the worst person in the world , and I&#39;m really shocked someone can say something like that. What the fuck ? really ? read your message again . I don&#39;t want anybody like your kind in the go community , please go away.</p></pre>leuro: <pre><p>You wrote fXXX I wanted to write if I could use proper English, thank you.</p></pre>jimuazu: <pre><p>I think the point is that there is a general culture of lower expectations of quality (&#34;it runs, ship it!&#34;) -- at least lower than some other languages or fields -- and that people recommend buggy projects as the best ones. It is true, what can you expect? Many new people coming to Go generally haven&#39;t the experience to know otherwise.</p> <p>I have exactly the same feeling going from a project with high standards and effective code-review to one where everything is more lax and standards slip and the whole project is constantly paying for it in terms of debugging and fixing avoidable bugs. Why don&#39;t they see that they are creating these problems for themselves? But it is cultural -- what can you do? If you try and change the culture (as this guy is trying to do) people don&#39;t like it much. Better just accept it and don&#39;t use low-quality 3rd party libraries that don&#39;t have a history of fixing bugs or accepting patches.</p></pre>klaaax: <pre><p>it&#39;s not like go doesn&#39;t have tools to assess the quality of a project tests? code coverage ? vetting and linting ? all built in Go. And it&#39;s not like people can&#39;t interact with authors on github and co. </p></pre>natefinch: <pre><p>It sounds like you got burned by using a bad library. That&#39;s unfortunate. But go is a relatively new language, and NAT uPNP is not exactly an everyday technology to use, so I&#39;m not surprised that there&#39;s only one semi-complete library for it right now. Heck, I&#39;m kind of surprised there was a library for it at all.</p> <p>I don&#39;t think there&#39;s anything wrong with people noodling around with a language to get a feel for it. We&#39;ve all done it. You did it. </p> <p>You can&#39;t just trust that some repo on github is quality code. You have to dig in and check for yourself. Run <code>go test -race -cover</code> ... are there data races? Is the code coverage better than ~85%? Are there issues filed weeks or months ago with no responses? If there are hundreds of forks, why is that? How do they differ from the original? Read the code. Are there docs for every exported type and function? Is the code easy to read and well organized? Does it clean up after itself (defer f.Close etc)? Read the tests, are they easy to understand? Are they thorough in their attempt to cover all use cases?</p> <p>I think a rating system for Go packages would be good... but that&#39;s a non-trivial exercise to put together and make trustworthy. Your idea for formal verification is really only applicable to packages that implement well-known standards. You can&#39;t formally verify my log rotation package, for example - it&#39;s not implementing a spec. That&#39;s what tests are for.</p> <p>Your post comes off as pretty grumpy, and is not really a very good first impression to give the community. You say the community needs to change, but it seems like maybe you need to change a little too. Don&#39;t be so grumpy! :) People are coding in Go and having a good time doing it. That&#39;s awesome! They&#39;re writing code with this language and feeling their way through its nooks and crannies. </p> <p>Not every weekend sideproject can be a replacement for OpenSSL (or whatever). Sometimes you just want to hack together some dumb library to try out an idea you had in the shower.</p></pre>jimuazu: <pre><p>How about self-classification, i.e. encouraging people who publish code to rate it as &#34;alpha&#34;, &#34;beta&#34; or &#34;stable&#34;. Then there can be meaningful discussion about whether the code meets the classification without discouraging people who just want to put stuff out there in the open-source style of sharing/cooperation. It is still valuable that people put out &#34;alpha&#34; code because someone else might build something much better from that starting point.</p></pre>Low-Eel: <pre><p>Of course, for me would be very nice. I mean, my software has &#34;STILL IN PROGRESS&#34; label. But we should understand people is writing code to have another line on their linkedin profile. So they don&#39;t like to say &#34;i wrote a beta&#34;. They want to write in the Linkedin that &#34;they wrote the new amazing 42&#34;.</p> <p>This is the point I am noticing. And this is, IMHO, the point which made other languages a mess to use.</p></pre>Low-Eel: <pre><blockquote> <p>It sounds like you got burned by using a bad library. That&#39;s unfortunate. But go is a relatively new language, </p> </blockquote> <p>Well, actually not just one. Initially I planned to use several libraries, and on 5, 4 were mostly JBOD. </p> <blockquote> <p>and NAT uPNP is not exactly an everyday technology to use</p> </blockquote> <p>well, if you want the router you have at home to open a tcp port thru the NAT, what you do? It seems to me most of home routers are using it. </p> <p>Anyway it was good, because it showed me golang doesn&#39;t needs so much libraries, often is faster to write them by your own than debug other&#39;s ones.</p> <blockquote> <p>I don&#39;t think there&#39;s anything wrong with people noodling around with a language to get a feel for it. We&#39;ve all done it. You did it.</p> </blockquote> <p>I am not going around to say people can use my code as a library for NNTP or whatever. Sure, I am writing beginner&#39;s code, but I don&#39;t pretend others can reuse it. What had made me astonished was not &#34;a library is bullshit&#34;. What mades me astonished is, when I ask for a UPnP library, everybody suggests to me this one.</p> <p>Which is very dangerous, if you think to OpenSSL and heartbleed.</p> <blockquote> <p>You can&#39;t just trust that some repo on github is quality code. You have to dig in and check for yourself. Run go test -race -cover ... are there data races? Is the code coverage better than ~85%? Are there issues filed weeks or months ago with no responses? If there are hundreds of forks, why is that? How do they differ from the original? Read the code. Are there docs for every exported type and function? Is the code easy to read and well organized? Does it clean up after itself (defer f.Close etc)? Read the tests, are they easy to understand? Are they thorough in their attempt to cover all use cases?</p> </blockquote> <p>all that you mention takes more time than writing it from scratch... this is the point. I am astonished by the amount of rest libraries are around, and actually, it is much easier to rewrite them from scratch than to follow all checks you mentioned.</p> <p>So if we proceed that way, given the high productivity golang achieves, we don&#39;t even need libraries. The other alternative (to write them from scratch) is a time saver. </p> <p>This is why I say: ok, let&#39;s have a formal verification tool. So we can test formally the library, and we don&#39;t waste such a time to debug other&#39;s code. </p> <p>I think we agree to debug other&#39;s code takes a terrible amount of time, right?</p> <blockquote> <p>You can&#39;t formally verify my log rotation package, for example - it&#39;s not implementing a spec. That&#39;s what tests are for.</p> </blockquote> <p>And how can I know it won&#39;t crash my program, or that is not a waste of time to use it? I am just doing it for fun, but if my time was paid, I won&#39;t spent it on each log rotation library I find. It is probably faster to write one from scratch.</p> <p>This is the point. </p> <blockquote> <p>Your post comes off as pretty grumpy, and is not really a very good first impression to give the community. </p> </blockquote> <p>Well, actually I started with the good feeligs, and perhaps, at the end, I just would like to have an automatic formal testing tool.</p> <p>As I said, I am starting to develop <strong>just for fun</strong> thanks to golang, after 10 years. I won&#39;t say this is &#34;grumpy&#34;, eing honest.</p> <p>But also I see some issues which needs, IMHO, to be addressed.</p> <p>Actually I won&#39;t have spent a minute of my time, if I was grumpy: grumpy people just says &#34;that&#39;s bullshit, I go home&#34;. I never had seen a grumpy employee coming and say &#34;I would like to have a tool for this and that&#34;. In my experience, they only mourn in the caffee room....</p></pre>natefinch: <pre><p>It sounds like you want some magical tool that will tell you that a library is good or not. I think <code>go test -race -cover</code> is the closest you&#39;re going to get. It&#39;s just not possible to write a tool that can determine completeness and correctness of arbitrary code. </p> <p>How do you use third party code in other languages? It should be the same for Go. Go isn&#39;t special in regards to there being more bad code out there than good code.</p></pre>Low-Eel: <pre><p>Again: I want to check a software against a policy I write. Which means , you are free to write what you want, but I am also free to check if it meets MY OWN policy. </p> <p>Of course people will write software according with THEIR policy. Which they are free to do. But also, I want to be free to understand if the software meets MY policy. </p> <p>Where &#34;MY&#34; could be my own one, or the customer&#39;s one. Which is an issue.</p></pre>szabba: <pre><blockquote> <p>well, if you want the router you have at home to open a tcp port thru the NAT, what you do? It seems to me most of home routers are using it. </p> </blockquote> <p>I think what <a href="/u/natefinch" rel="nofollow">/u/natefinch</a> was getting at is that most people don&#39;t write code where such a library is necessary or even useful.</p></pre>Low-Eel: <pre><p>Ok, but still, we have two problems:</p> <ul> <li>Bias saying: &#34;this is the library to use&#34;</li> <li>A library which is forked and included in a couple of dozen of application (like also synthing) and have some huge flaws.</li> </ul> <p>so, either <em>we</em> fight the bias, and stop saying &#34;problem solved&#34; each time a software <strong>pretends</strong> to do something, or <em>we</em> start checking the problem was <strong>actually</strong> solved. </p></pre>szabba: <pre><p>I don&#39;t thing formal verification is a solution for everyone (caveat: I&#39;ve never used it) or even for most people. I agree there is a problem, but I think it lies mostly in <em>our</em> behaviour.</p> <p>Side note: your original post sounded demanding and at places demeaning to other people. Not everyone is going to want to discuss with you if that keeps up.</p></pre>Low-Eel: <pre><p>Well, if you say &#34;golang is a better c&#34; you should consider many and many formal verification tools came with C. Is hard to say &#34;add formal verification to something which was designed with speed in mind&#34;, of course.But also, some &#34;light&#34; practices, coming from frama-c , could be integrated. </p> <blockquote> <p>Side note: your original post sounded demanding and at places demeaning to other people. Not everyone is going to want to discuss with you if that keeps up.</p> </blockquote> <p>well, when you complain because people is , by example, smokin where they should not, of course some people will feel pointed. When you complain against some <strong>convenient</strong> <em>bad practice</em>, you always get hate back. </p> <p>On the other side, if you want a bad practice to stop in a human group, you need to raise the problem, and get the hate back. Of course you could prefer to keep the bad practice, and don&#39;t wonder when the common environment becames a mess.</p></pre>szabba: <pre><p>&#34;Go is a better C&#34; is marketing. It&#39;s not a lie, just comes with small print -- in this case &#34;for the kinds of work and situations it was designed for&#34;. And lack of formal verification tools is not a problem for most of them.</p> <p>I don&#39;t say there&#39;s not a problem in the community. I&#39;m saying how you phrased your description was antagonizing. But enough of this. I&#39;m not hugely affected by the issue anyway, so that&#39;s about how much time I&#39;m willing to spend on it.</p></pre>dvirsky: <pre><p>You talk about some rating system for libraries. That&#39;s something I&#39;ve been thinking about from the moment I first ran &#34;go get&#34;. We do need some &#34;pagerank for libraries&#34;. I know godoc.org has an algorithm for rating them. But most algos like this one use things like github stars, forks, how many other libraries import them, etc - that&#39;s a good estimation but it&#39;s not always enough. And it&#39;s a problem not exclusive to Go, of course.</p> <p>For example, things that are usually not ranked: how many 2nd degree dependencies does this library introduce? How do they rank (that&#39;s a recursive algorithm like PageRank)? How well does it perform (how do you measure that at all? compared to what?)? How good is the API? How well is it documented? How stable it is (maybe issues/clones is a good estimate)? Is it actively maintained (maybe a small library that just works and has no bugs doesn&#39;t need any further maintenance? I have a couple of those that I use but barely touch).</p> <p>And all these are just guesses - you&#39;ll miss on great libraries that go under the radar, and on the other hand bad ones will bubble up in their rank. But you&#39;re welcome to try and formulate some algorithm to estimate and rank libraries that is better than what&#39;s out there today.</p> <p>But I don&#39;t think people should stop themselves from publishing libraries. BTW I&#39;m actually in the process of writing an API management framework, because the ones that are available were not on par with my company&#39;s needs, or were not maintained and documented well enough. And I&#39;m contemplating whether I should open it or not (it&#39;s using a couple of 3rd party libraries, but not too much). It&#39;s turning out great, but it just feels to me like I&#39;d just create noise for people if I publish <em>Yet Another Rest Framework For Go</em>. </p></pre>klaaax: <pre><p>Open source your stuff if you want to really. It&#39;s other people job to vet stuff not yours. You shouldn&#39;t feel like you need to hide your work because of idiots like <a href="/u/Low-Eel" rel="nofollow">/u/Low-Eel</a> who is a serious douche bag, one of the worse kind. On the contrary, good people will make constructive criticism about your work and might even contribute to make your framework better. Just don&#39;t let assholes stop you. You&#39;re not adding noise. It&#39;s not your job to do the vetting for others. You are contributing , unlike <a href="/u/Low-Eel" rel="nofollow">/u/Low-Eel</a> who is an entitled parasite of the worst kind. Hey but he has &#34;3000 clients&#34; so he&#39;s the king of the hill ! ... </p></pre>dvirsky: <pre><p>I&#39;m not shy about publishing my stuff at all, if you look at my submission history you&#39;ll see a couple of projects for example. It&#39;s just the specific case of this rest framework. I&#39;ll probably open it though.</p></pre>Low-Eel: <pre><p>Well, not exactly. I was thinking something like that, just after the last reply.</p> <p>After a little discussion , it comes to my mind actually I would prefer a formal verification feature added to the &#34;test&#34; framework of golang. I think it could solve the issue, since then everybody can verify how good is a library <strong>before</strong> of using it.</p> <p>Rating is ok, but also rating is not that useful into industry, like it is EAL certification, by example. So I would prefer google to add formal verification into the &#34;test&#34; library</p> <p>I don&#39;t want to <strong>stop</strong> people doing the library, I want to save the time of people adopting them. A tool for <strong>formal verification</strong> could have saved my time pretty well, I think</p></pre>dvirsky: <pre><p>Formal verification will give me a good insight into the library&#39;s current stability, but that&#39;s just one factor when I&#39;m choosing one. It won&#39;t promise me new features will be implemented, or that it performs well, or that the API that initially looks okay is in fact okay.</p></pre>Low-Eel: <pre><p>I am not saying formal verification can be the only criteria. But it could be quite a good MINIMAL requirement. </p> <p>Just for example, the heartbleed bug wouldn&#39;t have resisted to formal verification. Not that bad, right?</p></pre>dvirsky: <pre><p>I&#39;m not an expert in formal verification, but wouldn&#39;t 100% test coverage, plus some fuzzer tests to cover various inputs, be close enough to what you&#39;re looking for?</p></pre>Low-Eel: <pre><p>I think there is a misunderstanding about formal verification: formal verification permits you to check a code against a policy you define. By example, to reach EAL5+ you could need to exclude dynamic allocation of memory, like for aircraft the standard 187C requires. </p> <p>But this is an example. The point is: people is free to write whatever they like, but you need some way to quicly evaluate if some software is compliant with some policy. Which is yours.</p> <p>So if you want to use a library, you can check it against your policy. To &#34;test hard&#34; is good, but actually is not like &#34;I set my policy&#34;, or &#34;my customer set the policy&#34;, by example. In automotive and railways, often the customers are doing that on their side.</p> <p>Also when you do ASIC or SoC, the foundry is doing that before of burning the silicon. So I can&#39;t understand why this seems that a terrible idea... </p></pre>peterbourgon: <pre><p>Formal verification is not a cure-all. It&#39;s incredibly laborious, and often in conflict with other important properties of software, like ease of modification, speed to produce new features, etc. </p></pre>Low-Eel: <pre><p>I didn&#39;t say it is a cure-all. We are working wiht automotive and railways, so I know how hard it is. </p> <p>But actually once you define a policy, you can reuse it automatically. And often is the customer itself to define it. And also I don&#39;t say it is mandatory for who writes all software.</p> <p>But, having defined a policy, I can check against this policy any library, and decide quickly. So this is an acceptance criteria, not a project criteria. </p> <p>I don&#39;t see using formal verification as a must for people writing software, I see it as a self defense for people willing to use code written by others.</p></pre>leuro: <pre><p>fuck</p></pre>

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

823 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传