fix: avoid coroutine leaks when the dialecter initialization fails.
This commit is contained in:
		
							parent
							
								
									e9637024d3
								
							
						
					
					
						commit
						3ec26ef442
					
				
							
								
								
									
										6
									
								
								gorm.go
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								gorm.go
									
									
									
									
									
								
							@ -179,6 +179,12 @@ func Open(dialector Dialector, opts ...Option) (db *DB, err error) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if config.Dialector != nil {
 | 
						if config.Dialector != nil {
 | 
				
			||||||
		err = config.Dialector.Initialize(db)
 | 
							err = config.Dialector.Initialize(db)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								if db, err := db.DB(); err == nil {
 | 
				
			||||||
 | 
									_ = db.Close()
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	preparedStmt := &PreparedStmtDB{
 | 
						preparedStmt := &PreparedStmtDB{
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user