カプセル化の有害性、オブジェクト指向は愚かな考え

レス数が900を超えています。1000を超えると表示できなくなるよ。
1デフォルトの名無しさん
垢版 |
2020/06/18(木) 23:47:36.69ID:l/2SQUll
カプセル化(英語:encapsulation)とは、オブジェクト指向を構成する概念の一つで、オブジェクト内部のデータを隠蔽したり(データ隠蔽)、オブジェクトの振る舞いを隠蔽したり、オブジェクトの実際の型を隠蔽したりすることをいう。

かつて偏差値の低い学校向けの情報処理系教科書において「カプセル化は大変すばらしいものであり絶対に使うように」と大体的に宣伝された。

一方、カリフォルニア大学バークレー校の有識者を中心とした「インターネットを作った人たち」は「階層化の有害性」として「カプセル化は絶対にやめろ」としている。

https://monobook.org/wiki/%E3%82%AB%E3%83%97%E3%82%BB%E3%83%AB%E5%8C%96(%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0)
2020/07/05(日) 06:47:04.12ID:M+BkbwUs
>>810
他の言語を勉強したほうがいいぞ
どうもお前は、絶対に来るはずがない値が引数に渡された時、
そのテストしろって言ってるようだからな

「絶対にありえない値」なんだから仕様なんて作らない
他の型がない言語だったら、引数に渡されるオブジェクトなんか
それこそ無限に値なんてありえるだから

privateでも、ソースコードを修正して引数渡せるなら
そのテストをかけって言ってるようなもん
2020/07/05(日) 06:47:52.42ID:M+BkbwUs
>>812
> と、いうわけでPublicをテストすれば十分だしPrivateは(普通は)やらないという事を

頭悪そうだなw

この場合publicメソッドを呼んだらprivateメソッドを呼び出すんだから
privateメソッドのテストになってるだろ
2020/07/05(日) 06:47:57.37ID:9F15TCk0
少なくともグーグルの面接で絶対こないからテストしないとか言ったら
速攻落ちるよ。むしろ絶対こないのをやるものだからね。
2020/07/05(日) 06:49:10.31ID:M+BkbwUs
>>768

> まさかpublic・privateメソッドのテストをテスト工程でやる、
> public・privateメソッドを書いた人と別の人がやるって思ってないか?
>
> public・privateメソッドを実装中に、その作ったもののが正しく動くかどうか
> public・privateメソッドのソースを書いた人が、書いてる段階でテストするんだから
> 当然ソースを書いて(書き換えて)テストするに決まってるじゃん

と言ってますが、今の話と何の関係があるんですか?
「誰がテストするか」の話なんですが?
2020/07/05(日) 06:50:26.40ID:M+BkbwUs
>>815
だからpublicメソッド経由でテストしてるじゃんw

お前は、内部でprivateメソッドを呼び出しているから
publicメソッドのテストには、privateメソッドがそんな値を返そうが
そのテストは書かないのか?
2020/07/05(日) 06:53:15.16ID:M+BkbwUs
例えば>>805 の話だと
testChinがpublicメソッド、そのメソッドのテストとして
引数に1(なんで配列か知らんが)となるものを渡したら
Smallestが返ってくることというテストを書く

それは実際には内部でprivateメソッドを呼び出しているのだからfuncSのテストになってる
カバレッジを計測したら、privateメソッドであるfuncSの該当行は実行した(テストした)と計測される。
819デフォルトの名無しさん
垢版 |
2020/07/05(日) 06:54:07.51ID:9F15TCk0
え、コーディング中にちょろっとコード書いて動作確認とかを「テスト」って
呼んでたの?そりゃ噛み合わないわ。

開発手法の話をしてる時に「テストする」というからにはテストケースを書いて、
手動にしてもコードにしても実行したログくらいは残すものだが。

君はメソッド作る時エッジケースやらネガティブテストやら考慮に入れつつケースを
書いて実行したログも残してるの?変更のたびにやるの?やらんだろ。
2020/07/05(日) 06:56:15.75ID:M+BkbwUs
>>819
どれにレスしてるの?
ユニットテスト(かつ自動テスト)の話しかしてないんだが
お前がどこを呼んでそう思ったのか
具体的に指摘してみて
821デフォルトの名無しさん
垢版 |
2020/07/05(日) 06:56:44.73ID:9F15TCk0
publicをテストしたらprivateも呼ばれてるからprivate単位でテストしてる!って
ブレブレやなw

publicから呼ばれないprivateなんて一体誰がなんのために書くんだよw
2020/07/05(日) 06:57:27.80ID:M+BkbwUs
>>819
> 君はメソッド作る時エッジケースやらネガティブテストやら考慮に入れつつケースを
> 書いて実行したログも残してるの?変更のたびにやるの?やらんだろ。

変更のたびって、お前変更のたびにメソッドの仕様が変わるのか?
いきあたりばったりで開発してるんだな
2020/07/05(日) 06:58:49.78ID:M+BkbwUs
>>821
最初からそう言ってるだろ?
ブレるも何も、最初からそう言ってる



> 私の回答
> 短くまとめると、プライベートなメソッドのテストを書く必要は 無い と考えています。
>
> ほとんどのプライベートメソッドはパブリックメソッド経由でテストできるからです。プライベートメソッドは実装の詳細であり、自動テストのターゲットとなる「外部から見た振る舞い」ではありません。
2020/07/05(日) 07:00:51.32ID:M+BkbwUs
あ?まさかprivate関数の処理のテストをすればいいのに
private関数単独ででテストしなきゃだめだって思ってるのかw

あはは、関数単位でテストするのがユニットテストだって思ってるようだな
こりゃ、お・わ・ら・い・だw
2020/07/05(日) 07:02:37.00ID:BTTSshKd
メソッド単位でテストしろって言うのが組み込みおじさんだから話にならんよ
826デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:03:05.56ID:9F15TCk0
なんだこいつ気持ち悪い。
827デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:07:17.25ID:9F15TCk0
日本語もjavaも通じないからどうにもならない。
突然噛み付いてくる気持ちの悪いのは100%の確率でおかしいな。
2020/07/05(日) 07:08:18.45ID:M+BkbwUs
というふうに「技術」の話にレスができなくなったら
「人」(=俺)の話にすり替えるのが常套手段な
829デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:13:21.25ID:9F15TCk0
というかお前は誰だよ。Private単位でコード書き換えてもやるって言ってる
人間がいたからPrivate単位では通常のビジネス系ではやらないという流れなのに
突然「お前は素人だあ!」とか噛み付いてきても知らんがな。

タブもスペースもトランケートされる2ちゃんでインデントがとかくだらない
ことでマウント取りにくる暇があったらまず日本語を学べ。

以上。
2020/07/05(日) 07:21:09.73ID:BTTSshKd
「privateメソッド」を直接テストしろって言う人はどうするのがいいって言うの?

a 全てprivateメソッドに対しても外部にリフレクション等を使用したテストを書くべき
b privateメソッドにアクセスできるクラスなどにpublicなテストコードを書くべき
c もっと言い方法がある、こうだ!
831デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:22:11.60ID:LRfXHt7v
>>830
王家秘伝の技がある。
2020/07/05(日) 07:24:08.15ID:M+BkbwUs
>>830

>>798 じゃねーの?w

> 完ぺきにテストしたからといって製品の完全性を保証することはできません。
> したがってテストしないほうが良いのです。

つまり

privateにしたらテストできません。だからしないほうがいいのです。
完璧にテストした所で落ちない飛行機はありません
したがってテストしないほうがいいのです
833デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:24:58.59ID:9F15TCk0
しかしよくチンコのサイズテストwにマジで噛みつけるもんだ。
2020/07/05(日) 07:29:06.68ID:M+BkbwUs
>>833
あ、そういうテストだったの?w
コードしか見てないよw
2020/07/05(日) 07:30:17.21ID:M+BkbwUs
Chinってちんこのことだったんだな
funcSとかfuncBとかfoo、barみたいに意味がない単語じゃん
コードがクソすぎて意味が伝わらないいい例だな
836デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:34:08.81ID:9F15TCk0
無い場合You are a womanで9以下なら小さい、16越えりゃWow!で名前が
チンテスターなんだからわかってる人間は多いだろうな。
2020/07/05(日) 07:36:44.58ID:M+BkbwUs
>>836
じゃあint型の配列のlen(長さ)ってどういうこと?
配列がnullなら女で配列が複数あれば男?
何が複数なの?
838デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:36:59.87ID:9F15TCk0
ちなみにfuncなんとかというのは君の好きなグーグルあたりでも例ではよく使うわな。
BとSもbigとsmallだろうと英語得意なら当たりがつくけどね。なぜABじゃなくてBS
なのか。そもそもoutに出てんだし。
839デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:38:39.33ID:9F15TCk0
>>837
行があればChinkoクラスを作るとこだがスペースいらないで
intじゃなくてヌルポが出るものがarrayだからそれの長さで表してるだけだよ。
2020/07/05(日) 07:44:01.87ID:M+BkbwUs
> intじゃなくてヌルポが出るものがarrayだから
・・・

Java知らんのか?整数かつオブジェクトでも使えばいいじゃないか
具体的には教えてやらんよ。自分で勉強しな
2020/07/05(日) 07:46:53.71ID:wXNAUX4A
privateメソッドだからテストしないとか言ってるやつはキチガイ
早く死んでね
2020/07/05(日) 07:49:38.56ID:y7MN16M9
>>824
いや、やってもいいだろ
お前がやりたくないのは「たまたま」VisualStudioでやりにくいってだけの理由だろ
早く死んでね
2020/07/05(日) 07:53:17.11ID:M+BkbwUs
こういう事やって、NULLチェックが4倍に増えたー、テストも増えたーって
言ってるやつがいるなんて驚き。馬鹿かとw 以下擬似コードな

public func(value) {
 // valueのNULLチェック
 処理
 処理
 処理
}

public func(value) {
 // valueのNULLチェック
 foo(value);
 bar(value);
 baz(value);
}
private foo(value) {
 // valueのNULLチェック
 処理1
}
private bar(value) {
 // valueのNULLチェック
 処理2
}
private baz(value) {
 // valueのNULLチェック
 処理3
}
844デフォルトの名無しさん
垢版 |
2020/07/05(日) 07:56:16.74ID:LRfXHt7v
プロは俺だけだったか。
2020/07/05(日) 08:03:19.96ID:FjEgCO9/
そもそもprivateメソッドだからテストしないとか言ってるキチガイにまともな返答なんかいらない

そんなのどこの職場でも認められるわけないから
publicメソッド通したprivateメソッドに自分が想定したケースの値が全部入る保証なんかない
ある特定のケースのみそのメソッドの処理が欲しいときにしか呼んでないことあるだろ
つまりメソッド自体のテストはできてないしその方法でコードカバレッジ100%は無理だし
そもそもpublicから呼び出したprivateのコードカバレッジを100%にするなんて
作業が狂気過ぎてまともな脳みそ持ってるやつならやる前に無駄って理解できる

バカは早く死んでね
2020/07/05(日) 08:06:02.24ID:M+BkbwUs
そもそもprivateメソッドだからテストしないとか言ってるキチガイには
この言葉を授けよう

t-wadaのブログ
https://t-wada.hatenablog.jp/entry/should-we-test-private-methods#%E3%83%91%E3%83%96%E3%83%AA%E3%83%83%E3%82%AF%E3%83%A1%E3%82%BD%E3%83%83%E3%83%89%E7%B5%8C%E7%94%B1%E3%81%A7%E3%83%86%E3%82%B9%E3%83%88%E3%81%99%E3%82%8B


私の回答
短くまとめると、プライベートなメソッドのテストを書く必要は 無い と考えています。

ほとんどのプライベートメソッドはパブリックメソッド経由でテストできるからです。プライベートメソッドは実装の詳細であり、自動テストのターゲットとなる「外部から見た振る舞い」ではありません。

ただし、この議論にはプロダクトコードもテストコードも自分で書いていることという前提があります。プロダクトコードに手を入れられず、テストコードも無いレガシーコードに対しては、リフレクションは強力な手段です。

プライベートなメソッドのテストに関しては、4つの考え方があります。

パブリックメソッド経由でテストする
別クラスのパブリックメソッドとする
テスト対象の可視性を(やや)上げる
プライベートのまま、リフレクションでアクセスしてテストを書く
パブリックメソッド経由でテストする
多くの場合、そのクラスのパブリックメソッド経由でプライベートメソッドのテストも同時に行えます。テストできているか不安があるならテストカバレッジを確認しましょう。
2020/07/05(日) 08:10:31.93ID:FjEgCO9/
>>846
そいつプロジェクトで仕事したことあるのか怪しい部類じゃね?
2020/07/05(日) 08:16:36.05ID:IUsMolpf
publicを通した範囲でしかできないprivateのテストは網羅されてなく
メソッドの単体テストとして十分なテストは行われていません
あなたの意見は採用できません
できれば実際のプロジェクトを5つぐらい経験されてはいかがでしょうか?
849デフォルトの名無しさん
垢版 |
2020/07/05(日) 08:25:21.85ID:9F15TCk0
public通したprivateは単体としては怪しいというのはその通りだけど、
そもそも呼ばれないprivateを書くバカはいないわけで、条件があるから
書いてんだよね。で、条件をpublicの段階でテストするわけだから
ほぼ通ってるわけだよ。

上のチンコテストだとnullから16まで流せば全部通る。

違いは、上の例でprivateにnull突っ込んだらヌルポだわな。そこをテストするのは
コード変えなきゃいけないし、OOの大規模ビジネスソフトではそういうことは
やらない。それをやらなきゃいけない環境なら関数型でもいけるはず。
2020/07/05(日) 08:31:48.84ID:ckfZDtdO
>>849
できない時点でこの話は終わりさ
やらないわけには行かないんだから
90%できてても残り10%をどうやってもやる方法がないんだから
その方法はどうやっても採用できないし
わざわざする理由もない
別の方法ではできるんだから
851デフォルトの名無しさん
垢版 |
2020/07/05(日) 08:33:02.53ID:9F15TCk0
>>840
君のがpublic privateに関しては言ってることは正しいんだが
底抜けのバカだなあ。

整数かつオブジェクトwこのレベルの人と話してたのかw

はあ。。。

なんかいやになっちゃった。
852デフォルトの名無しさん
垢版 |
2020/07/05(日) 08:35:22.60ID:9F15TCk0
>>850
いやだから16まで流せば全部できてるけど。

ビジネス系ではやらないよ。組み込みで全部
テストしなきゃいけないというならわかるので
すれば良い。ただOOの手法とは違う。

デベロッパー千人のところでやってるの?
やってないでしょ?
2020/07/05(日) 09:13:35.35ID:iCbhqS6F
通ってればいいっていうなら単体テスト全否定だろw
結合テストなりで全部やりゃいいって話になる。
854デフォルトの名無しさん
垢版 |
2020/07/05(日) 09:23:53.74ID:9F15TCk0
>>853
だからその線引きをどこでやるのかっていう事で、
privateまで全部テストケース書いてエッジケースもネガティブも
全部やるなら関数型で良いんだよ。

別にバカにする気は無いし、関数型のが難しい場面もたくさんあるが、
大規模(デベロッパーだけで数百人)のOOプロジェクトやった事ある?
855デフォルトの名無しさん
垢版 |
2020/07/05(日) 09:30:39.94ID:9F15TCk0
上のチンコの例で言えば、funcSとfuncBのテストをテストケース書いて
コードを書き換えた上でやってドキュメントなりログなりで残すの?

だったらpublicでやれば良いし、そうやってpublicにするなら関数型でも
おんなじ事でしょ。

チンコがnullなのか16以上そこそこでかいのかまでしか関係ないわけで
privateがnullをハンドリングしてないとか無駄なんだよ。もちろん
命に関わるようなところではそれくらいの厳格さが求められる場合も
あるだろうが、普通のビジネスソフトではそこまでやらない。

他のチームが関わる場所を少なくするためにカプセル化するわけで、
そんな全部publicにしたら意味ないんだよ。
856デフォルトの名無しさん
垢版 |
2020/07/05(日) 09:41:54.39ID:LRfXHt7v
弊社はC2カバレッジ100%未満は出荷できませんけどね。
2020/07/05(日) 09:42:35.87ID:j0cUMVMZ
>>854
線引じゃねーよクソ野郎
publicでたまたま呼ばれた1パターンと
privateの網羅テストが同じになってたまるかアホかよ
クラスのなかにあるのでpublicから呼ばれたときだけ動けば
ルーチンとして不出来でもOKなんてあるわけないだろ
お前はクソだからもう死ねよ
858デフォルトの名無しさん
垢版 |
2020/07/05(日) 09:45:43.25ID:9F15TCk0
>>857
まあじゃあ君はprivateまでテストケース書いてやっとけば良いんじゃない?
誰も止めてないし。大規模ビジネスソフトでは世界的に言って普通ではないというだけで。

僕はあんまり関わることのないレベルの世界だけど、まあ多分一生関わらないので
君が良いならそれで良いと思うよ。
2020/07/05(日) 09:51:39.34ID:BTTSshKd
>>857
君は大変なんだねwテストがんばれーwww
2020/07/05(日) 09:54:43.54ID:bzHIXl0a
>>858
落としどころとしてはそんなところで良いんじゃね?
問題なのは「privateはテストするべきではない」なんて変な教義を押しつける人の方なんで。
861デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:02:55.49ID:9F15TCk0
>>856
正直QAやってたのは随分前の話だから最近のQAツールは知らんけど、
privateが全部通ってれば100%なわけで、そもそもprivateがある理由は
使われるためなんだから普通は誰も一回も使ってない場合なんかはないわな。
レベルが高くなると通らないケースも出るだろうが。だから線引きってこと。

チンコテストならnullから16までやれば100%通ってる。privateかpublicかって
のは関係ない。ただしprivateはnullをハンドリングしてない。それをどうするかって話。
2020/07/05(日) 10:03:22.77ID:iCbhqS6F
>>854
お前こそ大規模プロジェクトやったことないだろw
それだけ大規模だと逆にテストコード書かんわ(nttデータとかアクセンチュアとかな)
そんなクソプロジェクトを引き合いに出されても知らんわw
863デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:05:36.79ID:9F15TCk0
>>860
「べきでは無い」とは思わないけど、privateをデベロッパーの個人的な
チェックを超えてテストすることを求められるとしたら、何かプロジェクト的に
おかしいとは思う。
864デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:08:05.85ID:9F15TCk0
>>862
だから僕もNTTデータとかは知らんと上に書いてるけれども。

アメリカの大規模ソフトは中の人だし、他の会社のデベロッパも何人も知ってるので、
実際にアメリカの業界は知ってる。

君の「クソブロジェクト」ではないプロジェクトは会社名は出す必要はないが
例えばアメリカのERPとかそのレベルでなんなの?
865デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:09:56.64ID:9F15TCk0
だいたい質問を質問で返す人は答えるのに不都合がある人。

数百人のデベロッパーのプロジェクトをやったことなくても全く問題は
ないんだが(ロッキードのミサイルの制御の人とか数百人もいないし)、
「あるよ」とは帰ってこない。
2020/07/05(日) 10:15:56.23ID:bzHIXl0a
>>863
だからそれは別の話なんだからさ。
「privateなら必ずしも単体テストする必要はないけどやりたいならやれば?」
これでいいじゃん。
867デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:19:00.51ID:9F15TCk0
>>866
ちょっと弱いかな。「普通はやらんけどやりたかったりやる必要があるならやれば?」

くらい?privateを全部テストケース書いてエッジやネガティブやるとなると多くの場合
サグラダファミリアになるし、普通はやらない。

でもやりたいならやれば良いとは思うのでだいたいそういう感じか。
2020/07/05(日) 10:31:49.01ID:BTTSshKd
組み込みおじさんはそこに義務感を感じ、他者に強要するのだろう
難儀なこった
869デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:37:41.26ID:9F15TCk0
組み込みとかだと多くの場合そもそもOOあんまりいらんと思うのよね。

人工呼吸器の制御とかだときびしくやらないといけないのはわかるし、
やってない人工呼吸器とか俺も付けられたくないけどさw

OOのメソッドとかはちょっと違う話だわな。カプセル化とかは数百人になると
生きてくる。個人的には自分一人の個人プロジェクトでも使うけど。
数年後にまたやる羽目になったりした時に楽なので。
870デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:45:19.20ID:MQ9nuMmc
>>847
それは僕も思ってた
机上の空論っぽいんだよね
2020/07/05(日) 10:53:33.35ID:kFjTOHVy
>>867
どこに差があるのかよくわからんが、どちらにしても一行目は問題ないにしても
二行目はここに存在しない敵を攻撃している印象。
いちいち関係ない話を絡めなくてもいいじゃんと思うが、二度も書くということは
そっちが主張したい本音ということかな?
2020/07/05(日) 10:55:30.48ID:sn+7aSX4
OOPは理解している人とOOPを理解していない人が単体テストについて不毛な争いをするスレかな?
873デフォルトの名無しさん
垢版 |
2020/07/05(日) 10:58:45.46ID:9F15TCk0
>>871
いや、元々がpublicじゃなくてprivate単位でやれという話からなんだからその話だよ。

publicでprivateの分岐通ってるなら良いじゃんといなら誰も否定していないのでは?

逆にprivateで一度も通ってない部分があっても良いじゃんとも言っていないような。
if文書くのに絶対通らない物を書く人いるわけないでしょw

ただ、公式なテストとして、privateのレベルでテストケース書いてログ残してコード
書き換えてコンパイルし直してやるというのは少なくとも普通のビジネスのソフトとしては
一般的なベストプラクティスではないし普通はアメリカの大手一流ではやらないということ。
例外はあるとしても。
874デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:03:24.23ID:LRfXHt7v
土台が腐ってたら。
全部検査するほうが楽。
875デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:04:34.60ID:9F15TCk0
幸いそういうのには当たったことはないw
上に書いたように例外は認める。
876デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:09:23.64ID:MQ9nuMmc
アメリカの大手一流ってどこだろ?
877デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:11:04.89ID:MQ9nuMmc
アメリカや大手や一流が正しいとは限らないけどね
ボーイングの飛行機があんなことになってるように
2020/07/05(日) 11:11:13.65ID:9F15TCk0
まあ会社的にはプログラマなら全員知ってるとこ。それ以上は言わん。
879デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:13:19.35ID:9F15TCk0
>>877
だからボーイングの制御系とかはそもそも全然別の話。

もちろん正しいとは限らないけど標準なのは確かだわな。
日本初のOOより優れたこういうメソッドがある!というなら
もちろん喜んで聞くけどね。
2020/07/05(日) 11:14:37.74ID:kFjTOHVy
>いや、元々がpublicじゃなくてprivate単位でやれという話からなんだからその話だよ。
>ublicでprivateの分岐通ってるなら良いじゃんといなら誰も否定していないのでは?

そう、それが一致しているならいちいち関係ない話を絡めなくてもいいんでは?
public経由のテストで十分網羅できるのにそれでもprivateメソッド単位のテストが
必要なんて主張している人いたかな?そこに誤解があるんじゃないの?
2020/07/05(日) 11:15:16.65ID:9F15TCk0
>>880
いるから揉めてるんすよ。
2020/07/05(日) 11:16:31.89ID:M+BkbwUs
>>881
それはどれ?レスを教えて
883デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:17:47.72ID:MQ9nuMmc
アメリカの大手の一流がそうしてるから正しいのだという権威にすがった論理を
展開されておられたのでその会社ってどちらの会社なのって聞いてみたんだけど
そんな会社本当にあるの?
884デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:18:34.49ID:MQ9nuMmc
t_wadaの次はアメリカの大手一流か、議論の根拠が権威ばっかりやな
885デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:21:40.50ID:9F15TCk0
例えばこの方。

848デフォルトの名無しさん2020/07/05(日) 08:16:36.05ID:IUsMolpf
publicを通した範囲でしかできないprivateのテストは網羅されてなく
メソッドの単体テストとして十分なテストは行われていません
あなたの意見は採用できません
できれば実際のプロジェクトを5つぐらい経験されてはいかがでしょうか?


メソッド全部ちゃんとエッジケースやネガティブまでやれって業界があるのは
わかるし、必要だとも思うけど、それはOOのビジネス系だでは普通やらないということを
言ってただけなんだけど、バカだアホだお前は素人だといろんな方面から変に噛みつく
やつばかりでもう僕はいやになっちゃった。この人が噛み付いてきたということではないよ。

もちろんまともな人のが多いんだろうけどおかしな人のが目立つからね。
2020/07/05(日) 11:22:22.08ID:/MeFbFCW
いちいち論点ずらすな。
お前ら、何で争ってるんだよ。
887デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:23:41.69ID:MQ9nuMmc
OOのビジネス系ってどんな仕事?
そんないい加減なことやっていい仕事ある?
トラブってもうちうちでなーなーで済むようなBtoBの仕事?
自社内でしか使わないシステムとか?
888デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:24:18.36ID:9F15TCk0
アメリカの大手一流が不満なら自分の業界の実例をあげたらいかがだろうか?

privateをテストケース書いて全件やってるとこなんておそらくないぞ。あるというならあげれば良いだけの話。

テストツールどうやって動いてるねん。コード自動で書き換えてコンパイルし直しか。話がおかしいのすぐわかるだろ。
2020/07/05(日) 11:24:52.69ID:/MeFbFCW
まず、このスレの連中は議論する前に論理学を学ぶことをお勧めするよ。
あと、詭弁について調べろ。
890デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:25:24.17ID:MQ9nuMmc
>>888
アメリカの大手一流ってどこの会社なん?
891デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:25:52.62ID:9F15TCk0
>>887
だからアメリカ製のパッケージとかコンサルとの間でよく揉めてるだろ。これは「バグ」じゃないとか。DBだってよくある話だわな。

君はどんな仕事なの?
2020/07/05(日) 11:26:35.07ID:9F15TCk0
>>890
君の会社はどこなん?
893デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:27:26.12ID:MQ9nuMmc
>>891
アメリカ製のパッケージとかコンサルとの間でよく揉めてる仕事なん?
なにそれ? 何言うてんの? 何の仕事してるんよ
2020/07/05(日) 11:27:47.35ID:kFjTOHVy
>>885
それは網羅してないからダメという意見では?
そこに反論するならば「privateのテストを強制すべきではない」ではなく
「public経由でも網羅することは可能」ではないかね?(できるなら)
895デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:27:51.75ID:9F15TCk0
>>882
>>848
デフォルトの名無しさん2020/07/05(日) 08:16:36.05ID:IUsMolpf
publicを通した範囲でしかできないprivateのテストは網羅されてなく
メソッドの単体テストとして十分なテストは行われていません
あなたの意見は採用できません
できれば実際のプロジェクトを5つぐらい経験されてはいかがでしょうか?
896デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:28:29.72ID:MQ9nuMmc
>>892
アメリカの大手一流でこうしてるから、こうするのが正解なんやー
言うてたからアメリカの超一流ってどこなんよ? と聞いたんやけど
なんで言えへんの
2020/07/05(日) 11:28:59.86ID:YdQ981ul
>>870
新しい理論や手法を提唱する人には良くあることだと思うけど、その理論はある前提、ある側面では正しいけど、常に無条件に適用することは正しくないと本人は分かっていて、敢えてそういうことはわざわざ詳しくは説明しない。自分の論が有用な物だと主張したいがため、嘘はつかない範囲で相手が勝手に誤解してすごいと思わせるような物言いをする。
で、その理論に感銘を受けた人の一部が、理論の表面的な効能だけをありがたく受け取って問題点や前提条件などは正しく理解しないまま、受け売りの知識を他所で披露する。
そこで議論になると、本質をちゃんと理解してないまま自説を擁護しようとするから、無理が生じたり話が噛み合わなかったりする。
という流れでイマココなのかなと思う。
898デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:29:53.38ID:MQ9nuMmc
>>897
なるほどね、わかる気がする
2020/07/05(日) 11:29:56.16ID:M+BkbwUs
大手一流の名前を言うだけで逃げそう(笑)
900デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:33:32.02ID:MQ9nuMmc
足ガクガクになってまうよー
2020/07/05(日) 11:36:47.20ID:Ua1+WoRk
まぁ、単体テストでprivateを直接呼び出すのは変な話だけどな。
デバッグならともかく、単体テストでリフレクションによるprivate強制実行とか反則でしょ。
デバッグで許される理由は、バグを見つける可能性があるから。
単体テストで駄目な理由は、テストの合否判定が不当に変わる恐れがあるから。

というのが自分の見解だが、皆さんはどう?
スレが加速してからの途中参加だから、自分の発言に自信ないけど。
902デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:37:26.26ID:9F15TCk0
>>894
そもそもpublicを経由するのが網羅してないから、経由せずにprivate単位で
コード書き換えてテストやるべきという主張自体がOO的にはおかしいわけです。

見せたくないからprivateなわけで。

もちろんデベロッパー個人でコード入れて確認することはあるだろうけれども、
開発手順としてテストケース書いてログ残してというのは違う。

public経由で内部を網羅してるかしてないかは知ったことではない、というのが正解。
上の例で言えばfuncBやfuncSがnullをチェックしてようがしていまいが他のチームには
関係ないわけです。入り口でnullチェックしてれば。

個人的にはサイズがでかければprivateでも入れるけども、それをテストケース書いて
ログ残してと要求されたことはないし、普通はされんはず。少なくともアメリカでは。
903デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:38:33.09ID:MQ9nuMmc
GoogleであってもMicrosoftやOracleもバグのないソフトは作れないし
銀の弾丸的な手法があるわけもなく、アメリカ、大手、一流という箔付けに頼ってるだけでしかない
2020/07/05(日) 11:41:45.16ID:Xwol7cCi
せっかく匿名で議論できるのに
「アメリカの大手一流」とか言い出しちゃうところが哀れやわ
>>805の下痢便コード出た時点でスレ終了やろ普通
905デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:43:37.87ID:9F15TCk0
>>896
君の会社はどこなの?

アメリカ大手1流でブライベート単位でのテストケース書いたりした網羅的なテストは「していない」という証明は悪魔の証明だから無理だけど。全社で働いたわけじゃないし。

逆にアメリカ大手1流でやっているという証明は一件出すだけなのでGAFAのどこでも、マイクロソフトでもアドビでも簡単にできるのでぜひどうぞ。

ただ、なんかコピペで爆撃されたオートメーションツールでは、特にコンパイル必要な言語は、直接privateテスト出来ないよ。当たり前の話。
906デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:45:23.06ID:MQ9nuMmc
>>905
アメリカの大手一流ってどこなんよ?
907デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:45:48.03ID:MQ9nuMmc
その会社がやってるからすごいんでしょ、はよ教えてやー
908デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:47:16.10ID:MQ9nuMmc
もう何でもええから言うて、そしたら僕がすごーいって言うから、もうそれでええやんか
2020/07/05(日) 11:49:23.59ID:9F15TCk0
また別IDが下痢便とか発狂し始めた。

お前はほんとにウンコとかそのレベルのことが好きだな。
2020/07/05(日) 11:51:02.27ID:9F15TCk0
>>907
やって「ない」という話だけど。
まず日本語学んでやー よろしくなー
911デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:51:58.59ID:MQ9nuMmc
>>910
アメリカの大手一流ってどこなんよ?
912デフォルトの名無しさん
垢版 |
2020/07/05(日) 11:52:54.88ID:MQ9nuMmc
たぶんアップルは単体テストやってない、SSLでアホなバグだしてたから、あの会社適当だわ、しらんけど
レス数が900を超えています。1000を超えると表示できなくなるよ。
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況