MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

टेस्टकंटेनर्स + क्वार्कस + मोंगोडीबी के साथ एकीकरण परीक्षण

मैं आपके परीक्षण कॉन्फ़िगरेशन को देखे बिना निश्चित रूप से नहीं कह सकता, लेकिन मुझे लगता है कि यह docker run के साथ काम करता है और टेस्ट कंटेनर नहीं क्योंकि docker run एक निश्चित पोर्ट (हमेशा 27017) को उजागर करता है लेकिन टेस्टकंटेनर पोर्ट को उजागर करेगा 27017 यादृच्छिक पोर्ट के रूप में (परीक्षण मशीनों पर पोर्ट संघर्ष से बचने के लिए)।

क्वार्कस परीक्षण के साथ टेस्टकंटेनरों का उपयोग करने के लिए, आपके परीक्षणों को इस प्रवाह का पालन करना चाहिए:

  1. कंटेनर शुरू करें। यह आवश्यक है क्योंकि MongoDB के लिए यादृच्छिक खुला पोर्ट केवल बाद . के बारे में जाना जा सकता है कंटेनर शुरू कर दिया गया है।
  2. कंटेनर शुरू होने के बाद टेस्टकंटेनर्स से रैंडमाइज्ड पोर्ट प्राप्त करें, फिर कंटेनर पोर्ट पर निर्भर कोई भी टेस्ट कॉन्फ़िगरेशन गुण सेट करें। उदाहरण के लिए:

    static GenericContainer mongodb = new GenericContainer<>("mongo:4.2").withExposedPorts(27017);
    static {
      mongodb.start();
      System.setProperty("quarkus.mongodb.connection-string",
                         "mongodb://" + mongodb.getContainerIpAddress() + ":" + mongodb.getFirstMappedPort());
    }
    
  3. क्वार्कस शुरू होने दें। चूंकि क्वार्कस डायनेमिक कॉन्फ़िगरेशन का समर्थन नहीं करता है, क्वार्कस शुरू होने से पहले आपको मोंगोडीबी पोर्ट सेट करना होगा।


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. नेवला में db.collection.stats() कमांड क्या है?

  2. डेटाटाइम के क्षेत्र द्वारा नवीनतम MongoDB रिकॉर्ड प्राप्त करें

  3. बीएसओएन स्ट्रिंग (सीस्ट्रिंग/एनाम नहीं) के बाद पिछला 0x00 बाइट क्यों?

  4. $lter $gte . का उपयोग करके $fitler नेस्टेड सरणी

  5. NoSql के साथ ORM का उपयोग क्यों (जैसे MongoDB)